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PREFACE 


This reference manual presents a description of the software system of the GE-635 and GE-625. 
It is assumed that the basic philosophy of GECOS will be used by all installations in the execution 
of their computer programs. 


Chapter 1 provides a general description of GECOS, discussing many of its features and capa- 
bilities. Chapter 2, GESERV, describes the services provided to programs during execution. 
Most of the GESERV write-up, especially the area of input/output subroutines (and the Appendix, 
which relates to it) is presented for use by those who wish to program in assembly language 
(GMAP) without using GEFRC, or who wish to gain a more detailed understanding of the inner 
workings of the GE-625/635 software system. Chapter 3 presents the control cards involved 

in the flow of programs through the system, and will be of more universal interest. 


For ease of reference, an index is included listing all Master Mode subroutines and all control 
cards. 


Other Documentation: 


The following manuals contain information which will be of interest to users of the 
GE-635 or GE-625: 


GE-635 System Manual--CPB-371 

GE-635 File and Record Control Reference Manual--CPB-1003 
GE-635 Programming Reference Manual--CPB-1004 

GE-635 Sort/Merge Reference Manual--CPB-1005 

GE-635 FORTRAN IV Reference Manual--CPB-1006 

GE-635 COBOL Reference Manual--CPB-1007 

GE-635 General Loader Reference Manual--CPB-1008 

GE-635 Operator's Reference Manual--CPB-1045 

GE-600 Series Library Subroutine Manual 


Comments on this publication may be addressed to Technical Publications, Computer Department. 
General Electric Company, P. O. Box 2961, Phoenix, Arizona, 85002. 


@) 1964, 1965 by General Electric Company 
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1,.SYSTEM SUMMARY 


INTRODUCTION TO GECOS 


The General Comprehensive Operating Supervisor (GECOS) is the executive program which 
controls the sequencing and execution of all user programs on the GE-625 and GE-635. This 
supervisory system is designed to effectively control a multiprogramming environment, producing 
a significant increase in system throughput, with reduced turnaround time for the average job. 


The development of GECOS was motivated as much by the need for a more automated machine 
room operation as by the need to synchronize peripherals with the processor. 


e GECOS uses drums or dises for storage of system software, thereby reducing operator 
intervention. 
e The media conversion routines available on-line through GECOS keep operator problems 
tu all absvlule LLLLLdiLUit, 
MULTIPROGRAMMING 


Multiprogramming on the GE-625 and the GE-635 includes the following capabilities: 


Control is switched from a program awaiting an input/output operation to a program 
which can immediately use the Processor. 


Two or more programs can process I/O at the same time. 


Such functions as tape-to-printer and tape-to-card can be performed on-line by the 
GE-625 and the GE-635 concurrently with computation. 


The functions of GECOS are available without any special preparation by the programmer; 
he may write and execute his program unconcerned with the existence of other programs. 


User programs transfer control to GECOS without interfering with one another's proper 
execution. GECOS handles all necessary protection of memory and peripherals against 
illegal user access. 
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GECOS is permanently stored in the first 8192 cells of core and will automatically control the 
execution of up to eight user programs (all in core at the same time). GECOS calls in programs 
to be run, places them in their proper operating positions, and dynamically relocates the pro- 
prams as required after a program has terminated, 


HARDWARE ENVIRONMENT OF GECOS 


In addition to the standard GE-625/635 modules of Memory, Processor, and Input/Output Con- 
troller (IOC), the following hardware components are utilized by GECOS: 


8192 Words of Core 

786, 000 Words of Magnetic Drum (or Disc) Storage 
3 Magnetic Tape Handlers 

1 Card Reader 

1 Card Punch 

2 Printers 

1 Console (with Typewriter) 


Interrupts 


A set of interrupts is included in the GE-625/635 hardware which allows the program controlling 
the I/O commands to be aware of the status of each peripheral device at all times. Interrupts 
occur in the event a command has been completed, or when the on-line portion of off-line com- 
mands have been completed, or when there is a change in the availability of a device, Interrupts 
are also provided to signal the occurrence of errors or exception conditions in the execution of 
1/O commands. 


Faults 


The GE-625/635 hardware includes a comprehensive repertoire of fault traps which will occur 
whenever invalid or exceptional conditions are sensed in the Central Processor, These may be 
due to hardware malfunctions or programming errors; in some instances they are utilized to 
perform software control functions. 


Interval Timer 


The Central Processor of each GE-625/635 system is provided with an interval timer which mea- 
sures time to the nearest 1/64 of a millisecond, This is used as the basis for all time measure- 
ments maintained within the system. A primary function of the interval timer is to measure 

the length of time one program is on the Processor, and to signal when a specified time limit 

has been reached, 


Master/Slave Mode 


Two modes of execution exist in the GE-625/635 Processor: One is Master Mode, used by 
GECOS, in which it can execute all processor commands and address all of memory. The other, 
Slave Mode, is the mode in which all user programs are executed. A Slave Mode program is 
prevented from accessing memory not allocated to it, and from executing commands which 
could allow it to interfere with other programs, 
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Memory Protection 


Only the section of memory allotted to the currently operating program is accessible to a Slave 
Mode program; when GECOS switches from onc uscr program to another, it changes the areas 
of memory protection, opening one section and closing another. Memory protection is accom- 
plished with the help of the Base Address Register, which assigns a starting address, in units of 
1024 words, to a program. It indicates also how many 1024-word blocks are to be reserved for 
the program. When GECOS relocates a program, it uses the Base Address Register to facilitate 


the re-addressing of the program's relative addresses. 


HANDLING OF JOBS BY THE GE-625/635 


GECOS comprises two main segments: GEFLOW, which controls the flow of jobs and activities 
through the system (items 1, 2, 4, and 5, below); and GESERV, which provides services for use 
by a program during execution (item 3). 


The overall processing of jobs by the GE-625/635 system is broken down into five functions: 
Input Media Conversion, Allocation, Execution, Termination, and Output Media Conversion, 


1. Input Media Conversion (GEIN) 


When a job is presented to the system (that is, in the form of a card deck) it is processed by 
Input Media Conversion (GEIN), Processing is initiated simply by placing the loaded card 


reader in Ready status. 


With information obtained from control cards, GEIN generates a table (Control Stack) which 
lists information on peripheral requirements, plus storage and time limits, for use by the 
Allocator. Urgency levels indicated on the control cards are likewise kept in a table for later 
use by the Allocator. (The urgency indicator is a number from 1- 63, representing the relative 
importance of the job as assigned by operations. ) 


In the following discussion, the terms "job" and "activity" have specialized meanings. An 
"activity" consists of a single program (such as a FORTRAN compilation or an object program 
load and execution). A "job" is a set of activities which together constitute a problem or a 
production application. 


GEIN segregates these activities and presents them in an ordered manner to the Allocator. If 
necessary, the activity itself is separated into files by GEIN for convenience in later processing. 
(See Figure 1, page 4.) Thus when the Allocator is ready to select an activity for execution, 

all preliminary work has been done by GEIN. 
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Figure 1. Input Destination Under GEIN Control 


2. Allocation (GEALOC) 


The Allocator (GEALOC) assigns peripherals and a memory area to the activity. If the periph- 
eral requirements of an activity can be only partially met, the job is bypassed until all of its 
peripheral needs can be satisfied. GEALOC deals with the 18 most urgent jobs, as determined 
from the urgency table set up by GEIN. (The urgency indicator of a job is increased each time 
that job is delayed. When the urgency of a given job reaches a threshold value, other jobs are 
not considered for allocation until the peripheral requirements of this job have been satisfied, 
and it will be executed next.) No activity of a job is initiated until all prior activities of that job 
have been completed. 


Look-ahead Parameter. GEALOC allocates peripheral units to several programs in advance of 
execution as availability permits. This look-ahead feature allows the operator to perform time- 
consuming chores such as mounting of tapes while a prior activity is in progress. 
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3. Execution (GESERV) 


During program execution, 23 Master Mode Routines are available to the programmer via the 
MME instruction. These routines provide requests for service, exchanges of information, and 
control functions. 


GEIOS. The I/O Supervisor, GEIOS, controls all I/O operations between the peripheral devices 
and memory. GEIOS automatically performs all housekeeping functions involved in I/O data 
transfer between peripherai devices and memory, as, for example: 


® Queueing I/O commands on multidevice peripherals 
® Measuring time consumed on each peripheral 
@ Responding to all interrupts 


® Detecting I/O exception conditions and passing them to GEEPR for processing 


GEEPR and GEFALT. For I) O exception conditions or Processor faults, GESERV performs 
standard action or gives the programmer (or sometimes the operator) the option of handling the 
situation his own way. 


GEDISP. Maintaining high utilization of processor and peripherals with maximum synchroniza- 
tiva between tie two ip the funciion ui GEDISP. tne Dispatener. iacn time a program vields 
control to GECOS, the Dispatcher has the opportunity to give control to another program in 
memory which can make effective and immediate use of the Processor. Programs are examined 
for a turn at the Processor in the order of their urgency. 


GEROAD and GERELC. Yielding control of the Processor--done when a program is waiting for 
an I/O operation to be completed--is accomplished by either of two slightly different routines, 
the Roadblock and the Relinquish. The user is charged only for the Processor time used up to 
the point of Roadblock or Relinquish. I/O charges alone are accumulated after he has yielded 
control. 


Courtesy Call and GEENDC. A program which handles mostly I/O with only sporadic process- 
ing (file maintenance, for example) and needs to maintain just enough control to keep its periph- 
erals going will use the Courtesy Call, wherein a programmer initiates an I/O activity, then 
asks that he be given control (Courtesy Call) immediately after completion of that activity, for 
a very short time (enough to issue another I/O command). 


Forced Relinquish. It is conceivable that a Processor-bound program will compute for a long 
period without ever relinquishing control. To avoid a program "hogging" the Processor, 
GECOS sets the Interval Timer to interrupt whenever straight Processor time (without relin- 
quishing control) exceeds 62.5 milliseconds, Control is then given to the Dispatcher, with the 
interrupted program being considered inactive until some other program has had its turn. 


GE-600 SERIES GECOS 


4. Termination (GETERM) 
Activity (and overall job) termination is called upon by GECOS either asa result of user- 
program request or whenever it is determined that an activity must be removed due to a 
GECOS8-detected error. The responsibilities of this routine are as follows: 

e Providing a postmortem dump if the termination was due to error 

® Providing a termination sentinel on the system output file 

® Producing an accounting record on the system output file 

@ Deallocating peripherals 

® Communicating with the operator for file removal when necessary 


@ Deleting appropriate GEIOS, GEDISP, and GEALOC table entries 


After completing these tasks, the Termination module calls the Allocator for subsequent allo- 
cation of the released components to another activity. 


5. Output Media Conversion (GEOUT) 


Accounting information plus other output data are recorded on SYSOUT (the output collector) 
during execution. GEOUT processes the SYSOUT file, producing the printed or punched output. 


PROGRAMMING ALTERNATIVES 


GMAP--the General Macro Assembler--is the basic symbolic language used for coding on the 
GE-625/635. GEFRC--the General File and Record Control program--is an important tool for 
those programming in GMAP language. GEFRC provides automatic I/O routines to the 
programmer, saving him the trouble of writing calling sequences to the various GEIOS I/O 
routines. 


Since GEFRC handles all I/O in compiled programs, users of GEFRC or compilers (FORTRAN, 
COBOL) need not concern themselves with most of the MME routines in Chapter 2 (GESERV) 
except GEFINI and GEBORT. Programmers who do not use GEFRC or compilers will find 
Chapter 2 invaluable as a guide to using the many MME functions available. All GE-625/635 
users are expected to know the control cards requirements described in Chapter 3 (GEFLOW). 
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2. GESERV 


INTRODUCTION TO GESERV 


While the GEF LOW segment of GECOS controls the flow of programs from input to execution 
and from execution to final output, the GESERV segment performs services for programs 
during execution. This section of the manual describes the facilities provided by GESERV to 
the user program. 


It should be noted that if the programmer is using GEFRC for his I/O operations or is using a 
compiler, he need not concern himself with much of the information described in this section. 
Many of the Master Mode Entry routines will be called upon automatically by the compilers 
and GEFRC. The use of others is optional, at all language levels, but the user may find he 
wishes to employ their functions. 


Although the user need not use GH1OS and should not use GESYOT directly, an understanding of 
Alsu, GEEPR and GEFALT voin provide returns to whicn tne user may wish to respond, hence 
these should be clearly understood. On the other hand, the general user will never use 
GEDISP directly; it is described briefly for information purposes only. 


GEDISP comprises six functional modules: 


GEMME Master Mode Entry Routine. Allows a user program to place the 
processor in master mode to perform one of the 22 services 
available to each user (slave) program. 


GEIOS Input/Output Supervisor. Performs all input/output executed when 
the GE-625/635 is being run under GECOS control. 


GESYOT System Output Routine. Writes outputs on SYSOUT, the output collector. 
Prevents a user from writing too much on SYSOUT or malpositioning 
SYSOUT. Supplies needed information to GEOUT, the Output Media 
Conversion routine. 


GEEPR Exception Processing Routines. Takes standard actions in response to 
peripheral exception conditions or gives control to the user program or 
the operator where appropriate. 

GEFALT Fault Processing Routines. Performs standard actions on hardware 
faults and gives the user program the option of performing standard 
action, processing its own, or ignoring each program fault. 


GEDISP Dispatcher. Switches control of the processor from one program to 
another so as to maintain high utilization of processor and peripheral 
subsystems. 
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MASTER MODE ENTRY ROUTINE (GEMME) 


Purpose 


In the multiprogramming environment of the GE-625/635, programs in execution are, of 
necessity, restricted from accessing one another or any of the control programs. However, 
user programs do have the ability to call upon the master mode programs in GESERV for the 
various services which they require. A special instruction, MME (Master Mode Entry), is 
available within the GE-625/635 hardware, permitting access to GESERV facilities. 


Description 


When any MME instruction is encountered, the central processor places itself in master mode. 
It stores the instruction counter and the indicators (to allow reference and return to the 
requesting program) and then transfers control to the Master Mode Entry routine. 


The Master Mode Entry routine examines the address portion of the MME instruction, which 
should contain a value of 1 to 22, corresponding to the 22 valid requests a user program may 
make in GESERV. A nonvalid address in the MME instruction will cause the program to be 
aborted. 


Before returning to the user program, the Master Mode Entry routine will restore the 

exponent register and index registers 2-7. The contents of the A-register, the Q-register, and 
index registers 0 and 1 are not saved, the user should save these if necessary before performing 
an MME. 


There are three types of functions available through GEMME: 


1. Requests for service 
2. Exchanges of information between user programs and GESERV 
3. Multiprogram control 


They are described in detail on the pages which follow. 
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Requests for Service 


@ Perform Input/Output (GEINOS). This master pee entry is used in perfor ming all 1/0 on 

the GE-635/635. Users of GEFRC or compilers will not call GEINOS explicitly ; Symbolic - 
language progranmimers may use GEINOS via t alling sequence. A detailed disc cussion of 
MME GEINOS begins on page 27. 


Write on SYSOUT (GESYOT). Limited volume outputs from any program in execution may be 
written on SYSOUT. the system's output collector, if the user program so elects. These 
outputs are written by entering GESYOT, which protects outputs of one program against 
destruction by incorrect output commands of another program. GESYOT calls upon GEIOS, 
the I/O Supervisor (as do all other programs), to perform its I/O commands. For additional 
description of GESYOT, see page 42. 


Interchange of Primary and Secondary Logical Units (GEFILS) 


Initially 


LL ENN A : ’ 
Uieg) deQuascu, 


ie) 23 24 35 


Calling Sequence 


Entry L MME GEFILS 
Return L+1 Next instruction 
Results 
Pie 
11 12 13 14 17 18 35 


I0c 
Zero Dewees Ad- Channel Zero 
Address Address 
Description. The secondary logical unit (physical device) for this file code becomes the 
primary logical unit, and the primary logical unit in turn becomes the secondary logical unit. 
If no secondary unit has been assigned, the physical device assigned to the prumary, logical 


unit is assumed. The physical device address of the resultant primary logical unit is 
returned in the Q-register. 


This entry is for use with magnetic tape files only. It is the user's responsibility (the user may 
be GEFRC) to issue any mounting or dismounting instructions to the operator that may be 
required when files are switched. Users of GEFRC or compilers will not call GEFILS 
explicitly; symbolic-language programmers may use it via the calling sequence. 
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e Call tor the System Luader (GECALL) 


Calling Sequence 


Entry L MME GECALL 
Parameter L+1 BCI 1, XxXxxxx 
Parameter L42 ZERO Origin 

Parameter Li3 ZERO Transfer Address 


Description. The system program identified by xxxxxx (GMAP 656) is loaded into memory 
beginning at the location specified by C(L+2). If the C(L+3)=0, processor control will be 
transferred to the system program's entry point when loading terminates. If the C(L4+3)40, 
control will be transferred to the location specified by the C(L+3). 


In contrast to GERSTR, which handles the local catalog of programs and data, GECALL is 
used to reference the permanent catalog of System Programs (FORTRAN, GMAP, etc.) supplied 
by General Electric to an installation. 


@ Save Data (GESAVE) 
Initially 


C(Q) required: 
0 23 24 35 


Calling Sequence 


Entry L MME GESAVE 

Parameter L4+1 --- Identifier 

Parameter L+2 ZERO L (First word), No. of words 
Parameter L4+3 ZERO L (transfer address), 0 
Return L+4 Next Instruction 


Description. The C(L+2) specifies the location of the first word and total number of words 
which are to be saved on the file specified by C(Q). This file can be tape, random disc or random 
drum. The C(L#+1) is used as an identifier to uniquely identify this data. The C(L+3) specifies 
an address to which control will be transferred upon restoration of the saved file. This will be 
used only if the calling sequence for GERSTR contains 0 in the corresponding transfer address 
section, Bits 15 in the switch word must be set prior to the first referencing of any ''save"' 

file. 
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e Restore Data (GERSTR) 


0 23 24 35 
| FC 


Calling Sequence 


Entry L MME GERSTR 
Farameter L+1 --- Identifier 
Parameter L+2 ZERO Origin 

Parameter L+3 ZERO Transfer Address 
Return L+4 Next instruction 


Description. GERSTR restores data saved by GESAVE. The data is identified by the C(L+1) 
from the file specified by C(Q) into memory starting at the location specified by C(L+2). If 
C(L+2)=0, the data will be placed into the same memory locations from which it was saved and 
the origin and number of words from the corresponding GESAVE calling sequence will be 
inserted into word L+2. The C(L+3) specifies the address to which control is to be returned. 
If C(L+3)=0, control will be returned to the address previously specified in C(L+3) of GESAVE 
calling sequence. The transfer address from GESAVE will be placed in L+3 for the users 


information. Any modification to or extraction from this calling sequence will be done before 
input ot restored file. Tiis aliows overiay of te GERSTR calling sequence. 


e Special Interrupt Action (GESPEC) 
Initially 
C(Q) required: 


01 23 24 35 


0 
/ MBZ File Code 
1 


Calling Sequence 


Entry L MME GESPEC 
Return L+l Next instruction 


Description. The execution of an I/O command on some peripherals can be made dependent 
on the occurrence of a special interrupt by preceding it by MME GESPEC. At the present 
time, this feature is implemented for the card reader, printer, and DATANET-30. Through 
its use an I/O request can be queued awaiting a signal from a remote device or an 
anticipated human response at a peripheral. This is done by executing the above calling 
sequence with Q,-0. Such a queued request can also be canceled through the use of GESPEC 
with Qp=1. Examples of the use of GESPEC are given on page 40. 


GE6OO SERIES — 


-11- 


@ Checkpoint Dump (GECHEK) 


Initially 


C(Q) required: 
U 17 18 35 


L(Checkpoint File Control Block) MBZ 


Calling Sequence 


Entry L MME GECHEK 
Return L+1 Next instruction 


Description. A checkpoint dump is written onto the file identified by the C(Q)9.17- This 
file must have previously been opened via GEFRC. When the peripheral type is magnetic 
tape, any number of checkpoint dumps may be written on the file. However, when the file 
is identified as disc or drum, only a single checkpoint is permissible and must be the first 
item on the file. Each checkpoint dump will contain sufficient information for a restarting 
of the activity at a later time from the point at which the checkpoint occurred. 


One reservation should be noted. Both the restart procedure and the rollback procedure 
(see GEROLL) provide the magnetic tape file positioning capabilities only for those files 
which were “open” at the time of checkpoint and have GEFRC file control blocks associated 


with them. ; 


GECOS 
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e Reinitiate or Rollback (GEROLL) 


to 


avaaee MIS a a 


Nescription. Entry to GEROLL results in an output message to the operator, requesting the 


opcrator tc initiate a restart of the program. If the operator's response is restart, the 
program is restarted at the last checkpoint within the current activity if such a checkpoint 


exists. 


The user is advised to place a checkpoint (MME GECHEK) at the start of his program; 
otherwise, if no checkpoint exists, the program is aborted (since GELOAD releases any 
library files as well as memory itself prior to any possible reinitiation of an activity). 


If the operator's response is no restart, the program is also aborted. 


When restart is attempted, positioning of magnetic tape files is accomplished using 
information available within the user's file control blocks at the time of the checkpoint. 
The positioning of linked drum and disc files is accomplished using information contained 
in the user's peripheral assignment table at the time of the checkpoint. 


Alter the checkpoint recovery nas taken piace, Control is returned io tne audress 

specified by the contents of the address field of location 15 within the user's assigned 
memory. If at the time a checkpoint is taken (via GECHEK) the address field of this 

location is zero, the checkpoint routine will place the address of the MME GECHEK plus one 
into this location. 


Note: Following any file switch, file release, or memory release procedures, the user 
should issue a MME GECHEK. This will ensure that peripheral unit assignments have not 
been disturbed between current instruction and last checkpoint. 
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Multiprogram Control 


in any computer system capable of uverlapping input/output operations with central processor 
execution, synchronization of processor and 1/O operations is essential. When the processor 
consumes input more rapidly than the input devices can provide it, there is a delay each time the 
processor waits for a new input record. Similarly, when the processor develops output more 
rapidly than it can be disposed of by the output devices, a point is reached at which the processor 
must wait for an output area to be emptied. 


Under these circumstances, a reasonable improvement in overall throughput can often be 
realized through the use of various buffer strategies; but the great disparity between compute 
speed and I/O speed means that such ploys will often fail in attaining their intended goals. 


In the multiprogramming environment of the GE-625/635, a program is allowed to give control 
to GESERV at those points beyond which processing may not continue until I/O is completed. 
This approach has the dual advantage of (a) allowing the program which cannot proceed to avoid 
being billed for unproductive waiting time, and (b) allowing the system to look for another 
program which may use the available processor time. 


The following Master Mode Entries are provided to enable the user to take full advantage of the 
multiprogramming capabilities of the GE -625/635. 
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® Roadblock (GEROAD) 


Calling Sequence 


Entry L MME GEROAD 
Return Lil Next instruction 


Description. When a point is reached in a program beyond which processing may not 
continue until I/O is completed, control may be given to GESERV via the roadblock 
instruction MME GEROAD. GESERV will attempt to find another program that can use the 
processor until all of the I/O of the "roadblocked" program has been completed. Sometime 
after all of its I/O has been completed, the program which issued the MME GEROAD is 
given control again by the GEDISP function of GESERV., at the instruction following the 
MME GEROAD. (See Figure 2, page 16.) 


Users of GEFRC or compilers need not call GEROAD explicitly; symbolic -language 
programmers may use it via the calling sequence. 


e Relinquish Control (GERELC) 


Calling sequence 


Entry L MME GERELC 
Return L+i Next instruction 


Description, If, at the time MME GERELC is executed, the program has no outstanding 
1/0 requests, then transfer is made to GEDISP so that it may select a different program for 
execution. 


Otherwise (i.e., if I/O requests exist) execution of MME GERELC has exactly the same 
effectas MME GEROAD except that control will be returned to the relinguishing program 
after completion of any 1/O command. This is useful when the program is awaiting 
completion of a particular I/O command. The program may test each time it regains control 
to see if the awaited I/O operation has been completed and relinquishing control again if it 
hasn't. (See Figure 3 and 4, page 17.) 


Users of GEFRC or compilers need not call GERELC explicitly; symbolic -language 
programmers may use it via the calling sequence, 
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Object 
Program B 


GECOS Starts 
I/O Device Action 


I/O Action Requested 


Roadblock Dispatcher Action 


n ms, of highest priority 
Object Program A 


Program B I/O Action 
Terminate Routine 


62.5 ms. of 


Object Program A Return 


Dispatcher Action 


Object Program 
B Continues 


Figure 2. Roadblock 
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Object 
Program A | 


Relinquish Dispatcher Action 


Object 
Program B 


Figure 3, Relinquish 


Object 


(interrupt caused by timer runout if 62.5 ms) 
Program A od Be 


Dispatcher Action 


Object 
Program B 


Figure 4. Forced Relinquish 
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Continue 


Figure 5a. Courtesy Call 


1/O Action 
ted With 


GECOS Starts 


1/0 Device Action 


Roadblock 


| Ginterrupt caused by ee 
LTO device terni Fedexere 120 
Se tion Tersinate 


Routine 


rE 


Courtesy Cail 


cudin Lor 
roadbieck or te start another iG 


Cont iauc 


Figure 5b. Courtesy Call (with Roadblock) 
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e End Courtesy Call (GEENDC) 


Philosophy. Whe a user program surrenders coitroi of the processor through the use of 
GEROAD or GERELC, it will not usually regain control immediately after completion of the 
requested j/O. (iis successor program, even inough of iower urgency, wiii be aiiowed to 
maintain control for a fixed time interval or until it surrenders control. Then there may be 
more urgent programs which have also surrendered control and will regain control first. ) 


There are some circumstances in which one might wish to gain control without delay after a 
specific I/O operation has terminated. The most common example of this is a media 
conversion program where one wishes to keep the slower peripherals (such as card reader, 
card punch, printer) operating at rated speeds by giving a new I/O command immediately 
upon completion of each previous I/O operation. To achieve this capability, an address may 
be specified in any I/O request, to which control will be transferred instantaneously when 
the I/O operation terminates. Such a transfer of control is referred to as a "courtesy call." 


Although courtesy calls serve their intended purpose, their uncontrolled use would lead to 
severely undesirable consequences, such as the following: 
1. Possibility of recursive entries into the slave program 


2. f.oss of the sienificance of internal argenes chic to frequen demands of programs 
with many I/O requirements 


3. Degeneration of control by GESERV. because all programs could be executed 
under courtesy call, thus denying GESERV the opportunity to tend to its own needs 


To prevent the misuse of courtesy calls, the time which may be spent in a courtesy call is 
limited to that which is needed for the perpetuation of I/O. The interval timer is set to 
200 microseconds on entering a courtesy call on the GE-635 and 400 microseconds on the 
GE-625, If the courtesy call processing is not completed in the specified interval, it is 
considered to be a programming error and the program will be aborted. 


To signal the end of a courtesy call, the user performs MME GEENDC: 


Calling Sequence 
Entry L MME GEENDC 
No other method of ending a courtesy call is allowed. Furthermore, the use of GECALL, 


GESAVE, GERSTR, GEBORT, GECHEK, GEFCON, GEFILS, GEFINI, GERELC, GEROAD, 
or GEROLL is not allowed in courtesy calls. 


See figures 5a and 5b, opposite page. 
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Exchange of Information with GESERV 
e Date and Time of Day (GETIME) 


Calling Sequence 


Entry L MME GETIME 
Return Lil Next instruction 
Results 
C(A): 
0 1112. 23 24 35 
C(Q): 
) 35 


Time of Day 


Description. The date, asa 6-character numeric field, is returned in the A-register. The 
time of day is returned in the Q-register as a right-justified binary integer with a resolution 


of 1/64 millisecond. 


e Elapsed Processor Time (GELAPS) 


Calling Sequence 


Entry L MME GELAPS 
Return L+1 Next instruction 
Results 
C(Q): 
0 35 


Elapsed Processor Time 


Description. The elapsed processor time charged to the requesting program is provided as 
a right-justified binary integer in the Q-register. This represents elapsed time with a 


resolution of 1/64 millisecond. 


GECOS 
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@® Physical File Address (GEFADD) 


Tew idiies D112, 
Athitbket lly 
ai\ tee ity 
C(Q) required: 
24 24 35 


i) 
| MBZ | File Code | 


Calling Sequence 


Entry L MME GEFADD 
Return Lil Next instruction 
Results 
C(Q): 
11 12 13 14 17 18 35 


Zero Device as Channei anon 
Address : Address 


C(A): Ifa physical address exists for the file code supplied in the Q-register. the A-register 
will contain a non-zero value. However, if an invalid file code is specified by the user, both 
the A and @ will Cultaia 2eru whe seluril is made iu tie user. This use ui the A-register 
distinguishes between an unsuccessful search and a successful one in which the IOC, channel, 
and device addresses are legitimately all zero. 


Description. The device address, IOC address and channel address are returned in the 
Q-register corresponding to the file whose file code is supplied in the Q@. This MME is 
useful mostly for obtaining physical addresses for use in operator messages since slave 
programs may not use physical addresses in I/O commands. 


Users of GEFRC or compilers need not call GEFADD explicitly; symbolic -~language 
programmers may use it via the calling sequence. 
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e File Control Block Information (GEFCON) 


Initially 


C(Q) required: 
(e) 17 18 35 


L(First File Control Block) MBZ 


Calling Sequence 


Entry L MME GEFCON 
Return Lil Next instruction 


Description. The following information is placed in the file control block identified by the 
C . 


Link/Random Bit (provided for disc or drum) 

SYSOUT indicator 

Type of device 

Physical device address 

File serial number (provided only when the file is defined as magnetic tape) 
Reel sequence number (provided only when the file is defined as magnetic tape) 
File present indicator 

C or D disposition indicator (provided for magnetic tape) 


When additional file control blocks are linked to the origi i 
le ol blocks original file control block 
information pertaining to these blocks is also erovided.” pe nascar 


This master mode entry is provided for the lusi i 
secret ae oe p exclusive use of GEFRC and is not expected to be 
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e Sct Switch Word (GESETS) 


| 46-bit mask | 


Calling Sequence 


Entry L MME GESETS 
Return L+1 Next instruction 
Results 
C(Q): 
0 35 


C(Switch Word) 


Description. For each bit position of the Q-register that contains a 1. the corresponding 
bit position of the Switch Word is set to 1. For each bit position of the @ that contains a 0, 
ihe Cudiespunding vil pusition ul tie Switch Woid is uudisiusbed, The susuilaul seliing of 


the Switch Word is returned in the Q. 
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e Reset Switch Word (GERETS) 


Initially 


C(Q) required: 


0 35 
36-bit mask 


Calling Sequence 


Entry L MME GERETS 
Return L+1 Next instruction 
Results 

C(Q): 


ie) 35 
C(Switch Word) 


Description. For each bit position of the Q-register that contains a 1, the corresponding 

bit position of the Switch Word is set to 0. For each bit position of the Q that contains a 0, 
the corresponding bit position of the Switch Word is undisturbed. The resultant setting of 

the Switch Word is returned in the Q. 


e Release Peripheral File (GERELS) 


Calling Sequence 


Entry L MME GERELS 
Parameter L+1 ZERO No. of files 
Parameter L+2 BCI 1,0000F1 
Parameter L.3 BCI 1,0000 F2 
Fl, F2,..., FN=File Codes 
Parameter L+N+1 BCI 1,0000 FN 
Return L+N+2 Next instruction 


Description. For each file code listed in the sequence, the corresponding peripheral file is 
de-allocated from the requesting program. Dismounting instructions are issued for this file 
if it is on magnetic tape and has disposition code D. The C(L+1) identifies the number of file 
codes appearing in the calling sequence. Disposition code S, indicating a saved file, will 
prevent release of that file. 


GE-GOO SERIES GECOS 


-24- 


@ Release Memory (GEMREL) 


C(A) required: 
0 17 18 35 


Return Address | MBZ 


C(Q) required: 
0 17 18 35 


Number of Words of Lower Memory Number of Words of Upper Memory 


Calling Sequence 


Entry MME GEMREL 

Return Defined by C(A). When lower memory is released, there will be a change 
in the base address of the requesting program, and in this case the return 
address 1s assumed to be relative to the base address after memory 
de-allocation. 


Description. The amount of memory specified by C(Q) is de-allocated from the requesting 


PLURLdI & Luidi dOSIBIIEU INELULY. ACiudi LudinUivy UL-diivCalivii is iii iluitipies ul 1624-word 
blocks. If memory remaining after release is less than 2048 words, the program will be 
aborted. 
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@ Terminate (GE FIND 


Calling Sequence 


Entry MME GFE FINI 


Description. Ali peripherals allocated to this activity, except those which have been 
designated as ''save,"' are de-allocated, and dismounting instructions are issued if necessary. 
Core storage allocated to this activity is released. 


Note, It is the user's responsibility to insure that all his I/O activity has terminated before 
executing this Master Mode Entry. If this is not done, I/O which is incomplete at activity 
termination is in danger of being lost. 


MME GEFINI is the standard method of bringing an activity to successful completion. 
Therefore, the programmer is expected to code this in all programs. 


e Abort (GEBORT) 


Initia lly 


C(Q) required; 
: 29 30 35 


ee ee 


Calling Sequence 


Entry MME GEBORT 


Description. All peripherals allocated to this job are de-allocated, and dismounting 
instructions are issued, if necessary. A memory dump of the user's core storage is 
produced on SYSOUT. Core storage allocated to this activity is released. Any remaining 
activities for this job are deleted. 
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INPUT/OUTPUT SUPERVISOR (GEIOS) 


Features 


lok Pate 


initiates activity on the Card Reader, Card Punch, Printer, Magnetic Tape Unit, Drum, Disc, 
Perforated Tape Reader /Punch, and DATANET-30. In addition, GEIOS provides the following 
features and capabilities: 


e@ Symbolic-to- Physical Unit Translation. Users of the GE-625/635 will refer to files symbol- 


ically in the various source languages available within the software system. This enables 
maximum flexibility of assignment of files at execution time and permits a degree of device 
independence of the files that a program may call upon. GEIOS will convert the symbolic 
file designations to absolute physical assignments at execution time. 


e File Protection. GEIOS insures that one program may not refer to the files of another. In 
this way, it is possible for several programs to be in core concurrently without any of them 
suffering damage to their files due to the erroneous behavior of another. 


® Simulated Tape Processing on Disc/Drum. GEIOS provides a method of processing on disc 


and drum which simulates the serial mode of processing normally peculiar to magnetic tape. 
This mode of processing not only provides a degree of device independence to computer con- 
figuration but also allows the opportunity to reduce program setup time by eliminating the use 


r es at 4 c ree 
Vi GHaRNULIL Lape bUL SUlLIL Lilies. 


e@ Supervision of Interrupts. GEIOS responds to all I/O interrupts and takes appropriate action. 
The programmer will normally not be required to concern himself with the interrupt 
system of the computer. 


@ Queueing of Input/Output Requests. GEIOS maintains queues of I/O commands. A single 


command can be queued for each I/O device. In multidevice channel subsystems, such as 
magnetic tape and disc, GEIOS will select queued commands for execution in the order in 
which they were requested. 


e Utilization of GEIOS with Crossbarred Magnetic Tape Subsystems. If the primary channel 
is busy at the time I/O is to be initiated, GEIOS will automatically select an alternate chan- 


nel (if available) on a crossbarred maynetic tape subsystem. 


e Fseudo-Command, In the special case of the typewriter, a Pseudo-command is provided 
which will allow a programmer to type a message requiring an answer, By the use of this 
command, it is guaranteed that the answer to a question will follow in sequence behind its 
asking, (See Write then Read, page 30) 


e Awareness. The GE-625/635 I/O equipment provides information to the central processor 
which allows GEIOS to maintain awareness of the status of each peripheral device. GEIOS 
maintains tables which allow it to record such information as: a magnetic tape is rewinding; 
some peripheral device is in a Power Off condition; a magnetic tape handler is in Ready 
status, or has been rewound and is in Standby status. 
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@® Accounting. GEIOS keeps a complete record of the time spent by the central processor and 
cach peripheral for every program executed, These statistics are later recorded on cards 
for use in billing aud analysis. 


Tnifiation of Tomi. Output 


When a user program wishes to initiate 1/O, it execules a MME GEINOS which is followed by a 
Select sequence specifying additional information pertaining to the 1/O operation. When the I/O 
supervisor is entered as a result of the MME GEINOS, the file code in the Select sequence is 
used as a basis tor determining physical duvice and channel, If the channel is not busy, GEIOS 
will load the communication cells (subsequently to be examined by the IOC) and will issue a 
Connect instruction whieh will cause the FOC to iniliate the requested I/O operation, 


If, when GEIOS receives a request to perform an 1/O operation, it finds that the channel upon 
which the request was made is busy, it will queue the request if it was made on a multidevice 
channel and return control to the requesting program. If in any event the request queue on the 
device and chanel fer which the request was issued was found by GEIOS to be full, GEIOS will 
ember the location at which the request was issued and give control to another program by 
Nspatcher (GEDISP). 


wavy of {} 


Termination of Input/ Out put 


Whenever an l-O operation terminates (as signaied by a termination interrupt) control will be 
eiven tu the termination portion of GEIOS after all registers and indicators for the interrupted 
program have been saved. Assuming that the termination was successful (that is, no error 
eaialition existed) GEIOS will return the status of the peripheral device to the program which 
requested the termination I/O operation and remove the terminated request from the queue for 
the device which was involved, If there is another queued request which can now be serviced, 
CORIO imma iately initiates pertinent 1/O action 


NGrs ay arias diac 


After GEIOS has processed the termination interrupt and attempted to start other 1/0 as des- 
cribed above, it will determine if a courtesy call was requested. If it finds that a courtesy call 
was requested, it will give control to the user program for a limited time at the specified cour- 
tesy call address. After the courtesy call (if present) has been processed, the registers of the 
computer are restored to the condition at which the interrupt occurred and control is returned 
to the interrupted program. 


The above infarmation has presented a considerably condensed description of the sequence of 
events that takes place in the execution of a typical 1’O operation. 


Ground Rules for GEIOS 


One I/O request will be queued for each peripheral device. 


For those channels which can control more than one device (for example, magnetic tape or disc), 
I/O requests will be serviced in the order in which they are received. 


The magnetic disc commands Seek. Read Continuous and Release Seek, Write Continuous and 
Release Seek, Writc Continuous Verify and Release Seek, will be provided. 
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Seek commands addressed to different file anits are overlapped automatically by GEIOS to im- | 
prove the total throughput of the dise channel. 


Inhibition of interrupts will be Kept to a minimum so as to reduce response time to such ovccur- 
rences as peripheral termination. 


Return from an I/O request submitted from within a courtesy caii wili always be made directly 
to the requesting program, even if other master mode programs require service. 


Return from other I/O requests will be made directly Lo the requesting program unless master 
mode programs require service. 


After responding to a peripheral interrupt and paying any courtesy calls requested, GEIOS will 
always return to the interrupted program. 


Routines to handle the most frequently occurring 1’O cornmands and circumstances will be coded 
for speed, even at the possible expense of increasing execution time in abnormal cases. 


e File Codes. A file code is a two-letter symbolic designation used universally to refer to 
TES in ihe Grr - 4) DoD SUilLWware syvSsiel ii fhe orovtaiiined 1S writine i GMAP (Svmboiie) j 
language, but not using GEFRC, the file code will be provided by the programmer using a BCI 
pseudo-operation. The file code is contained in the calling sequence following the MME 
GEINOS which initiates each i/O operation. If the programmer is using GEFRC to perform 
his I/O operation, GEFRC will automatically synthesize a GEINOS calling sequence which 
contains an appropriate file code (specified in the FILCB macro). 


In FORTRAN source languave, the file code is created as a function of the file number re- 
ferred to in the READ or WRITF commands in the FORTRAN source language. For instance, 
WRITE (1) would imply file code F1. In COBOL source language, the file name is related to 
the file code in the Environment Division using the "assigned to" clause. 


When a user prepares his program for execution, be will prepare file control cards. (See 
GEFLOW section, page 51,) These will relate the specific file that is to be used in each 

case to the file code by which it has been referenced internally. GEIOS will translate the 

file code references at execution time to the actual physical file assignments made by 


GEALOC. 


e Mass Storage Files. Two types of mass storage files are treated by GEIOS. The first is 
the familiar random access file in which a seement of contiguous storage is allocated on the 
dise or drum to contain the information of some unique file. GEIOS may refer to one or 
more such files for each program. It will make each file appear as though it begins at block 
0 and extends upward to an allowable limit. Gi1OS, with the assistance of hardware features, 
will prevent a user from writing beyond the area allocated to him on a mass storage device. 
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For many applications it is desirable to be able to interchange disc, drum, and magnetic tape 
as storage media. To achieve this interchangeability, a type of file referred to asa linked 
file is provided through GEIOS. ‘This type of file causes the mass storage devices lo per- 
form as if they were maguetic tape, if the following restrictions are observed: 


The file may not be backspaced, torward-spaced, or changed in density. 


Standard system format must be used. 

(Variable block size, 320-word maximum; block sequence number and size of block for 
each data block; high density, binary mode; variable-length records with record size con- 
trol word; standard header and trailer labels.) See GE File and Record Control manual, 
pave 23, fur details on System Format. 


e Write then Read. In the multiprogramming environment of the GE-625/635, it is necessary 
occasionally to type a message on the typewriter which requires an operator reply. If such 
messages were typed just as they were encountered at execution time, it would often be 
difficult for the operator to keep up with the multitude of questions which might present them- 
selves to him within a short time interval. 


To alleviate this problem, GEIOS provides an I/O pseudo-command which consists of a Read 
Typewriter command to be executed immediately following the successful termination of a 
preceding Write Typewriter command. This pseudo-command will allow the operator to 
respond to each message as it is presented to him. 


If after 30 seconds the operator has not responded to a question which has been typed, the 
console will automatically terminate its Read command with a unique substatus indication 
to the requesting program. At this time the requesting program can reissue the command 
and continue to do so until the operator responds. 
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GEIOS Usage 
In general, a request for I/O is made by means of the instruction MME GEINOS followed by a 
Select sequence of three or five words, depending on the number of peripheral commands in the 


sequence. Normally, the Select sequence contains three words: Operation Word, Identification 
Word, and Return Word. 


A request to perform I/O using a three-word Select sequence may be viewed schematically as 
fo 


llows: 


MME GEINOS 


I/O command to be executed 


ZERO File Pointer, DCW Pointer 


One word containing file identification 


First of a list of words describing 
memory locations to be read or 
written (scatter/gather list) 


Select sequence 


Firstof two words (status returns) de- Entry point to user's 
scribing the circumstances under which courtesy call routine 
execution of the request was terminated 


The first word of the Select sequence--the operation word--specifies what actual operation is to 
be performed; the second--the identification word--indirectly identifies which peripheral device 
is involved and what data, if any, is listed. The additional word--the return word--returns in- 
formation on the success or failure of the command's execution plus a special entry to the user's 


program. 


GECOS 
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Certain I/O requests involve two related operations which must be performed sequentially. 
These are: Seek, then Read or Write Disc; Select, then Read or Write Drum; and Write, then 
Read Typewriter. In these cases, the Select sequence is five words long. 


In a 3-word Select sequence, then, the order of words is: 


Operation word 1 
Identification word 1 
Return word 


while in a 5-word Select sequence, the order is: 


Operation word 1 
Identification word 1 
Operation word 2 
Identification word 2 
Return word 


The formats of the individual words in a Select sequence and descriptions of the various fields 
therein are given on the pages following. 
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a. Operation Word 


0 5 6 17 18 22 23 24 29 30 35 
Devi a 
evice Ppa toc : B Control Count 
| Command | ipecials | Command [z | I j 


Mn Antal afi 
The octal configur 


A. 
software are as follows: 
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All Devices Octal Code 
REQS Request status 00 
RESS Reset status 40 
Card Reader 
RCB Read Card Binary 01 
RCD Read Card Decimal 02 
RCM Read Card Mixed 03 
Card Punch 
WCB Write Card Binary ii 
WCD Write Card Decimal 12 
WCDE Write Card Decimal Fdited 13 
Printer 
WPR Write Printer 10 (see Note 1) 
WPRE Write Printer Edited 30 (see Note 1) 


Magnetic Tape 


RTB Read Tape Binary 05 
RTD Read Tape Decimal 04 
WTB Write Tape Binary 15 
WTD Write Tape Decimal 14 
WEF Write End-of-File 15 (see Note 2) 
WFM Write File Mark 15 (see Note 2) 
ERASE Erase 54 
BSR Backspace Record (s) 46 
BSF Backspace File (s) 47 
FSR Forward-S pace Record (s) 44 
FSF Forward-Space File (s) 45 
REW Rewind 70 
REWS Rewind and Standby 72 
SLD Set Low Density 61 
SHD Set High Density 60 
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GECOS 


Disc 


SDIA 
RDIC 
WDIC 
WDICV 


Drum 


SDRA 
RDR 
WDR 
WDRV 
DRCV 


DATANET-30 


WDN 
RDN 


Perforated Tape 


RDPT 
WPT 
WPTE 
WPTSC 
WPTDC 


Console Typewriter 


RTYP 
WTYP 


Seek Disc Address 

Read Disc Continuous 

Write Dise Continuous 

Write Disc Continuous and Verify 


Select Drum Address 
Read Drum 

Write Drum 

Write Drum and Verify 
Drum Compare and Verify 


Write DATANET 
Read DATANET 


Read Perforated Tape 
Write Perforated Tape 
Write Perforated Tape Edited 


Octal Code 


34 (see Note 3) 
25 
31 
33 


34 (see Note 4) 
25 
31 
33 
11 


10 
01 


02 (see Note 5) 
11 
31 


Write Perforated Tape, Single Character 16 
Write Perforated Tape, Double Character 13 


Read Typewriter 
Write Typewriter 


03 
13 


Note 1: Printer Slew commands will not be recognized, so that GECOS can have the 
ability to assign the output either directly to the printer or to another device for 
subsequent printing. When slewing is to be performed, the escape character and 
appropriate slew character must appear in the line to be printed. 


Note 2: An end-of-file or tape mark is written by a combination of the '’write tape 
binary'' Device command and the "write single-character record" IOC command, 


Note 3: When requesting disc I/O involving data transfer, the Select sequence 
Contains two operation words; the Device command in operation word 1 must be 
Seek Disc Address, and that in operation word 2 must be the appropriate Read 


or Write command. 
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GECOS 


Note 4: When requesting drum I/O involving data transfer, the Select sequence 
contains two operation words; the Device Command in operation word 1 must be 
Select Drum Address, and that in operation word 2 must be the appropriate 
Read or Write command. 


Note 5: Before issuing a Read Perforated Tape command, the program should 
first issue an REQS or RESS to insure that a reader plug board is present. If a 
Read Perforated Tape command is issued and there is no reader plug board 
present, tape movement will begin and will continue until the end of the input 
reel is reached, at which time a "Device Attention -- Out of Paper" status will 
be sent. 


The various IOC command codes and their meanings are as follows: 


00001 = Continuous Mode Non-Data-Transfer (used for backspacing or 
forward-spacing records or files on magnetic tape, and for all 
other non-data-transfer operations including Request Status 
and Reset Status) 


00010 = Card Punch (used whenever a binary or decimal card is to be 
punched) 


00100 = Write Single-Character Record (used to write an end-of-file 
uF Lape Mark Un Magnelic tape) 


TY: rp, oT rel fa, 1 5 a ee g + a he 
Vw bape adds Va LUOLM Uiidy LUL Lilitadl DLad t-~Up) 


00000 = Unit Record Transfer (used for all operations not defined above) 
The Control field must be zero except in the following cases: 


When writing an end-of-file or tape mark on magnetic tape, the 
control field contains the binary representation of the character to be 
written as a single-character record, 


For disc I/O involving data transfer, the control field of operation 
word 2 must contain 010100. 


The Count field must be zero except in the following cases: 


When the Continuous Mode Non-Data-Transfer (00001) IOC command 
code is used, the count field must be 000001 unless the operation is 
“backspace or forward-space n records," in which case the count 
field contains n as a binary integer. 


When the Card Punch (00010) IOC command code is used, the count 
field must contain 001011 (=11, 9)- 


For dise or drum I/O, the count field (initialized by GMAP) in operation 
word 1 must contain a binary integer whose value is equal to the 
number of commands in the Select sequence. 
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b. Identification Word 


) 17 18 35 
In identification word 1, the File Pointer is the address of the word containing the File 
Code used to identify the file to which the 1/O request pertains. In identification word 2, 
the file pointer, regardless of actual value, is assumed to be the same as that in 
identification word 1. 

The format of the File Code word is as follows: 
) 17 18 23 24 35 


PAT Pointer File code 


The PAT pointer must initially be zero; it is subsequently maintained by GEIOS and should 
not be altered by the user program. If the PAT pointer is inadvertently modified, the 
offending program may destroy one of its own files, or it may be aborted, but in no case 
can the files of another program be affected. 


The file code is the two-character code used for purposes of file identification. (See 
page 29.) 


The DCW (Data Control Word) pointer contains the address of the first of one or more DCW 
words which specifies and is used in the control of data transmission. If no data 
transmission is involved, there are no DCW words; in sucha case, the DCW pointer must 
be zero. 


Note: The Seek Disc Address and Select Drum Address commands involve the transmission 
of an address as data, and therefore require a DCW word and a DCW pointer. 


The format of a DCW word is as follows: 
0 17 18 21 22 23 24 35 


Ac 
Data Address MBZ tion Word Count 
Code 


The Data Address contains the location of the first word to be transmitted or, when the 
action code specifies a DCW transfer, the location of the next DCW word. 
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In the case of the DCW word associated with a Seek Disc Address or Select Drum Address 
command, the word referred to in the data address field must, for random files, be 
initialized with the desired relative block address each time that I/O is requested on that 
Hiles the:block address.is converted te Ghooluts by CRIOS atthe time of 1/O initiation, 

For linked files, all maintenance of the block address is performed by GEIOS. 


Note: When reading or writing linked files, a standard record length of 320 words will 
always be assumed. Since a block on disc accommodates 40 words, GEIOS increments 
the block address by 8 (except across link boundaries) whenever a linked file is accessed. 


tae Ma 


For linked drum files, the block address increment is 5, since a block contains 64 words. 
For random files, however, transmission can start at any block of 40 words on disc, or 
of 64 words on drum, by means of the relative block address. 


The Action Codes and their meanings are as follows: 
00 -- Transmit and Disconnect. Move the number of words toor from memory 


specified by the count and then terminate the I/O command. 


01 -- Transmit and Proceed. Move the number of words specified by the count 
to or from memory, then continue to the next DCW and do as it indicates. 


10 -- Transfer to DCW. Don't move any data. Go to the DCW at the address 
specified in this DCW and do as it indicates. 


11 Non-transmit and Procced. Skip the number of words specified in the 
count of this DCW, then go to the next DCW and do as it indicates. 


The following restrictions apply to Action Codes: 


The first DCW ina series must not contain the action code 10. 


The DCW referred to by the DCW pointer associated with a Seek Disc Address 
or Select Drum Address command must contain the action code 00. 


The action code 10 must not be used in a DCW associated with drum I/O unless 


it is executed between 64-word blocks. 


The Word Count contains a binary integer indicative of the number of words to be 
transmitted under control of the DCW. A count of 0 is interpreted as if it were 4096. 


The following restriction applies to Word Count: 


The DCW referred to by the DCW pointer associated with a Seek Disc Address 
or Select Drum Address command must contain a word count of 1. 


GECOS 
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ce. Return Word 


0) 17 18 35 


Status Return Pointer Courtesy Call Address 


Status Return Pointer. This field contains the address of the first of two sequential words 
which are set to zero by GEIOS when the I/O request is received, and into which the status 
returns will be placed when I/O has terminated. Note that if the requested 1/O action is 
Request Status or Reset Status, the status conditions will be returned to the user program 
exactly as GEIOS receives them from the IOC. Otherwise, the Exception Processing 
Routine will have taken all possible recovery action on any indicated errors before GEEPR 
returns the final status to the program. In any case, no status returns will be made if the 
Status Return Pointer is zero. 


It should be pointed out that status returns in response to Rewind, Rewind and Standby, 
Set Low Density, or Set High Density commands are meaningless other than to signify 
that the 1/O action has started, Status is not provided when any of these actions terminate. 


In addition, when an I/O request involves two or more I/O actions (for example, 
Select, then Read Drum), the status returns pertain to the request as a whole. 


The formats of the two status return words are as follows: 


012 5 6 11 12 15 16 17 i8 23 24 29 30 35 
Tj M| Major Substatus MBZ Ij M IOc MBZ Record Count 

Bi Status B Status Residue 
0) 17 18 20 21 22 23 24 35 


Data Address Residue Char. R/| Ace Word Count Residue 
Count W tion 


The Termination Indicator (T) will be set to 1 when the I/O (and any pertinent recovery 
action) has terminated. 


For a complete discussion of Major Status and Substatus, see Appendix, Page 69. 


The Interrupt Indicator (I) will be set to 0 if the status was returned by the IOC as a 
result of a termination interrupt, but will be 1 in the case of an initiation interrupt. 


The latter occurs in the following cases: 
The command was Request Status or Reset Status. 


The command was Rewind, Rewind and Standby, Set Low Density, or Set High 
Density with respect to magnetic tape. 
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The command Backspace Record, Backspace File, Write End-of-File, or Erase 
was addressed to a magnetic tape at the load point and was consequently rejected. 


or the Perforated Tape Reader/Punch when 


saa tree 1 on Terre 
US Will ALWA 


xcept fur a Request Status in which case this status will 
by GEIOS as iti e 
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eceived from the IOC. 
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The Record Count Residue pertains to magnetic tape backspace or forward-space 
operations only. It reflects the number of records remaining that were not spaced over 
due to detection of either the beginning of tape or an end-of-file mark. (Note: an end- 
of-file mark will have been counted as a record. ) 


The second status return word reflects the condition of the last DCW processed by the 
IOC when the 1/O terminated. The fields in this word are as follows: 


The Data Address Residue is the address +1 of the last complete word of data moved. 


The Character Count reflects the number of characters transmitted in the last word 
if it was a partial word; if will he zero if the last word was complete. 


The Keaqg/ Write Control (R/W) is used by the IOC for cantral purpeses. Normally it 


The Action Code is that which was provided in the DCW (see page 37). 


The Word Count Residue reflects the number of words still left to be transmitted under 
control of the DCW when I/O terminated. 


Courtesy Call Address. This field contains the address to which GEIOS will transfer as 
soon as the specified I/O has terminated. Courtesy calls will be made only if the I/O 
resulted in a termination interrupt. Certain restrictions apply: 


It is illegal to use any of the following instructions within a courtesy call: 

MME GEBORT, MME GECALL, MME GECHEK, MME GE FCON, MME GEFILS, 
MME GEFINI, MME GERELC, MME GEROAD, MME GEROLL, MME GERSTR, 
MME GESAVE. The appearance of any of these instructions within a courtesy 
call will cause the program to be aborted. 


If only a single I/O request is given during a courtesy call and it pertains to the 
device whose I/O termination caused the courtesy call, there will always be room 
for the request in the queue for that device; in this case the I/O request will be 
processed normally. On the other hand, if any 1/O request is submitted during a 
courtesy call to a different device from that on which 1/o terminated, room in the 
queue can not be guaranteed; if the queue happens to be full, completion of the 
courtesy call will be postponed until the queue can accommodate the request. 


Return from a courtesy call must be made by means of the instruction MME GEENDC. 
The length of time permitted to a courtesy call is limited to 200 microseconds on the 


GE-635 and 400 microseconds on the GE-625, exclusive of the time required for GEIOS 
to process I/O requests. If this time limit is exceeded, the program will be aborted. 
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Usage of GESPEC (Special Interrupt Action Request) 


At certain times it may be desirable to issue a latent request for I/O which would be 
executed upon the occurrence of some external condition. This capability is provided in 
GEIOS by entering master mode at GESPEC before issuing the conditional I/O request. 


This facility may be used in connection with three peripherals: Card Reader, Printer, 
and Remote Terminals. 


Card Reader. A particular card reader will normally be assigned to accept system inputs 
on the GE-625/635; its identity will be standard for each installation. This system reader 
may be utilized also by user programs such as bulk media conversion. Its availability for 
use by GEIN will be announced to the operator on the console typewriter. 


] GEIN will be activated automatically when the operator places the deck in the hopper and 
pushes OPERATE/RESET. This ability to initiate input media conversion without the use 
of the operator's console is made possible by a latent Read command issued by GEIN 
whenever the system reader is available for operator use. 


When GEIN is entered, the sequence MME GESPEC, MME GEINOS, MME GEROAD 
is executed. 


The MME GESPEC refers to the system card reader; the MME GEINOS requests a 
Read operation (this Read command will not be executed until a special interrupt is 
issued by virtue of the reader changing from Standby to Ready status.) The 

MME GEROAD prevents GEIN from executing until the Read is complete. 
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Printer. Controls are provided on the General Electric Common Peripheral High-Speed 
Printer which allow an operator to control both printer and input media from the printer. 
The controls available to him are: 


Print One Line 

Backspace One Line 
Forward-Space One Line 
Backspace to Top of Page 
Forward-Space to Ton of Page 
Backspace One Block/Rewind 
Print PREV LINE IN ERROR 


The operator controls obtain their capabilities through the use of a standard subroutine; 
the hardware merely returns a numeric substatus corresponding to depression of each 
of the control switches. These controls will be used whenever a Device Attention major 
status is returned in response to a Write Printer command. 


When using the printer, the programmer should write a CALL PRTATN at the point in his 
program where status returns are to be tested. The PRTATN subroutine will test the 
major status for the Device Attention condition and return control to the main program 
if this condition is not found, If Device Attention is encountered, PRTATN will perform 
MME GESPEC, MME GEINOS, MME GEROAD. 


The command portion of the MME ekeys wilt call fqn the execution of a Reauest Status 
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cleared the Attention condition and readied the printer by depressing the Operate/Reset 
switch. The status returned will be Device/Channel Ready major status and a numeric 
substatus which will depend on what control switch the operator depressed. 


The PRTATN subroutine will then perform the action specified. (See the Library Sub- 
routine Manual for a detailed description of PRTATN. ) 


Remote Terminals, To assure rapid response to requests from remote devices via the 
DATANET-30, a latent Read command may be issued, If a need arises to write to a 
remote terminal after the command has been issued but before an external request arrives, 
the latent command may be removed by issuing another MME GESPEC with the Q-register 
set negative. This will allow the Write to be issued, after which the system can be 
reconditioned to receive information from remote terminals as before, 
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SYSTEM OUTPUT COLLECTOR (GESYOT) 


Purpose 


A collector tape is provided in the GE-625/635 for recording outputs of limited size. This 
collector works in conjunction with two additional tapes which supply output to GEOUT (the 
Output Media Conversion routine). 


Many outputs which are to be ultimately printed or punched are of relatively small size but occur 
frequently. To eliminate the need for assigning a separate output unit for each such output, the 
GESYOT facility is provided in GESERV. With this facility the user is able to write all of his 
small outputs onto the unit referred to as SYSOUT, thereby alleviating the need for the mounting, 
dismounting, and allocation of many output files. Within certain format limitations the user may 
place any or all of his output files on SYSOUT so long as the total output from any activity does 
not exceed 10, 000 unit records and the total punch output does not exceed 1, 000 cards. 


Some reports and decks, of course, will exceed the limits specified for writing to SYSOUT. 
These should each be assigned to its own output unit and converted to printed page or punched 
cards through the use of Bulk Output Media Conversion. 


In addition to being able to receive several outputs from a single program, SYSOUT may receive 
the outputs of several programs concurrently. This capability quite effectively utilizes the GE~ 
625/635 hardware. But note that user programs are prohibited from writing on SYSOUT via the 
Master Mode Entry to GEINOS. This eliminates the danger of one program performing an 
operation which would adversely affect the objectives of another (for instance, one program 
might have inadvertently rewound the output collector tape so that the outputs from many other 
programs might have been destroyed), Instead of the user program writing on SYSOUT via a 
normal Master Mode Entry to GEINOS, the special subroutine GESYOT is provided, GESYOT 
has as its primary purpose and capability the writing of records on SYSOUT on demand from 
various user and system programs. In addition to protecting information recorded on SYSOUT, 
GESYOT provides control information which will be used ultimately by GEOUT. 


The specific functions of GESYOT are: 


1. To write records on SYSOUT on demand from user or master mode programs 


2. To maintain a record count of the number of print lines and punch records written 
to SYSOUT by each user program and to abort the program if the number of print 
lines exceeds 10, 000 (or the limit specified on the user's LIMITS card) or if the 
number of punch records exceeds 1, 000 


3. To provide consecutive block sequence numbers (The outputs produced by each 
user program will start with block sequence number one.) 


4, To coordinate the utilization of tapes with GEOUT and to redirect SYSOUT output 
to an alternate collector tape and/or the drum during switching of collector tapes 
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Usage 


To write a record on SYSOUT from a user (slave mode) program, the following calling sequence 
ia execu tad: 


So CACC ULC. 


Entry L MME GESYOT 
Parameter L +1 ZERO L (File Control Block) 
Return L +2 Next instruction 


Normally, this GESYOT calling sequence is used only by GEFRC. GEOUT expects a certain 
format, which GEFRC produces automatically. Use of GESYOT outside of GE ERC is discouraged, 
since it would be very cumbersome and error prone. 
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EXCEPTION PROCESSING ROUTINES (GEEFR) 


Interrupts 


The IOC and the peripheral I/O devices of the GE-625/635 hardware system generate signals 
which interrupt the processor whenever a significant event takes place with regard to I/O. For 
example, interrupt signals occur when an 1/0 command has not been successfully initiated, when 
an I/O operation terminates successfully or otherwise, when a magnetic tape rewind is com- 
pleted, when any peripheral device changes from a standby to a ready condition, or when a 
device at a remote terminal desires to communicate with the GE-625/635. 


In general, whenever an interrupt takes place, the IOC also transmits status information so that 
GEIOS can determine the specific cause of the interrupt. If the status indicates that the 1/O was 
completed successfully and that the hardware is ready to perform a subsequent I/O operation, 
GEIOS returns the status information to the user program and immediately starts the next I/O 
(provided, of course, that a request iswaiting in the queue). On the other hand, if the status 
reflects some abnormal condition, GEIOS will pass the status information to GEEPR (Exception 
Processing routines) for further action. 


Types of Exception Routines 


The occurrence of exception conditions is rare compared to the frequency of occurrence of 
normal interrupts. Therefore, the Exception Processing routines are called from the drum as 
overlays so as to save space incore. The Exception routines can be classified into several 
categories: 


1. Those whose occurrence is normal but which require operator response. Exception 
conditions such as full stacker, empty hopper, chad box full, fall in this category. 
These interrupts are handled entirely by GEEPR and will never be seen by any user 
program. If one of these conditions occurs, GEEPR will issue appropriate in- 
structions to the operator and will resume operation on the affected device as soon 
as the operator has complied. 


2. Those whose occurrence is normal and which are handled by the requesting 
program. Such conditions as end of file, end of reel, and magnetic tape at load 
point, provide information to which the user program may wish to respond. In 
such cases, the status and substatus are merely passed on to the user program 
which will take appropriate action. 


3, Those whose occurrence is caused by unsuccessful completion of the 1/0. This 
class of exception conditions is handled in a variety of ways depending upon the 
nature of the error and the peripheral device involved. 


The Appendix describes in detail the various exception conditions and the action taken by GEEPR 
in each case. The information contained in the Appendix applies to exception conditions 
encountered in slave programs. Special consideration must be given to the occurrence of 
errors in master mode programs. If an I/O error which cannot be recovered is sensed ina 
master mode program, the operator is informed and given an opportunity to initiate a 

Rollback procedure. The Rollback will restart execution at the last available checkpoint. 
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FAULT PROCESSING ROUTINES (GEFALT) 


, th s: enters the master mode and 
ry location within master mode memory. The 
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ioCation Ol this instruction: pair. is-deter mined by the particular fault The’instructions:save 
the contents of the instruction counter and indicators and transfer processor control to a master 


i 
mode program for interpretation of the fault. 


Standard Action vs. User Option 


Faults are classified as either program or hardware faults according to the possible cause. If 
a fault could have been caused by a program error, it is considered a program fault; if it could 
only have been caused by a hardware error it is considered a hardware fault. 


A standard action is taken by the system for any hardware fault that may occur, and for any 
program fault which the user chooses not to handle himself. 


When the system processes a fault, it produces a comment on SYSOUT. Wherever possible, 
the standard system action allows processing to continue. 


In the case of program faults. the user has the option of substituting his own fault routine for 
that provided by the system. If he exercises this option, the SYSOUT comment will not be 
produced, Lhe opuon, which may be eAcl cased by a slave piupiain in piuccssing faults, if 


controlled by a fault vector. 


Fault Vector 
The fault vector comprises the first 14 locations (relative to the contents of the Base Address 


register) of each slave program and is organized into seven successive pairs with each pair 
being related to one type of fault. 


Base Address 


|» Fast com, Comm Go 
2: ae 
2 = 
4 From cwa 
.o2 ene 
+ i0 (Lockup) 


GE-GOO SERIES GECOS 


#452 


If the user wishes to override the system option on a particular fault, he places a transfer 
instruction (TRA) to his own Fault routine in the second word of the pair corresponding to the 
fault. 


If the user wishes to ignore the fault, he places a return instruction (RET) in the second word of 
the pair with an address pointing to the first word of the pair. 


If the user wishes to go along with the system option, then the second word of the pair must be 
zero. 


Bit positions 0-17 of the first word of the pair will always contain the C (Instruction Counter) +1 
at which the fault occurred. The status of the indicators when the fault occurred will be stored 
in bit positions 18-35, 


Standard Fault Processing Procedures 


The following list indicates the standard action taken by the system for each fault. 


Program Faults 


1. Illegal operation code 
Description: An operation code of all zeros has been executed. 
SYSOUT: ILLEGAL OP CODE AT XXXXXX 
Action: Abort 

2.  Lockup 


Description: A program lockup (for example, a TRA to its own address) 
has existed for 64 milliseconds. 


SYSOUT: LOCKUP AT XXXXxXKX 
Action: Abort 
3. Divide check 
Description: A divide check fault has been generated. 


SYSOUT: DIVIDE CHECK (This message will be added to the end of the 
execution report) 


Action: Continue (If the divide check is caused by division by zero, the 
largest positive number is returned. In the case where 
the divide check is caused by division other than zero, 
the largest magnitude and correct sign is returned, 

In either event, bit 29 of word 25--accumulated fault 
status--of the user program will be set to 1.) 
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4, Overflow 


Description: An arithmetic overflow, floating-point underflow or floating- 
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the execution report at termination time) 
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Action: Continue (The largest magnitude and correct sign are returned when 
the fault is detected as floating-point overflow, and bit 22 
of word 25--accumulated fault status--of the user program 
is set to 1. When the fault is detected as floating-point 
underflow, 0 is returned and bit 23 of word 25--accumu- 
lated fault status--is set to 1. On all other overflow 
conditions, the result is left undisturbed and bit 21 of 
word 25 of the user program is set to 1.) 


5. Command 
Description: The processor has given a Connect or has attempted to alter 
the mask or protect registers and is not the control processor 
for that memory or is not in the master mode, or the processor 
has given a Connect to a channel which is masked or switched 
off. 


SYSOUT: ATTEMPT TO ALTER MASK OR PROTECT REGISTER AT XXAXKK 


Action: Abort 


6. Memory 
Description: The memory did not respond within 50-100 us to a data cycle 
request, or no physical memory existed for the address, or a 
program in Slave mode referenced protected memory, or the 
memory closed out a double-precision or BAR cycle, or 
program exceeds boundary. 
SYSOUT: MEMORY FAULT AT XXXXxXX 
Action: Abort 
7, Fault Tag 
Description: The Fault Tag has been recognized. 


SYSOUT: (None) 


Action: Abort 
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Derail 


x 


Description: The instruction Derail has been executed, 
SYSOUT: ILLEGAL OP CODE AT XXXXXX 
Action: Abort 

9. Connect 
Description: The Connect flip-flop has been set. 
SYSOUT: ILLEGAL OP CODE AT XXXXXX 
Action: Abort 

10. Master Mode Entry 
Description: The instruction MME has been executed. 
SYSOUT: (None) 


Action: (See page 8.) 


Hardware Faults 
11. Startup 
Description: A power startup has occurred. 
SYSOUT: (None) 
Action: Continue 


12. Execute 


Description: The EXECUTE switch on the processor control panel has been 
activated. 


SYSOUT: (None) 
Action: Continue 
13. Shutdown 
Description: Power will be shut off in 1 millisecond. 


SYSOUT: (None) 


Action: Discontinue program processing and attempt to communicate this 
fault condition to the operator. 


GECOS 
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14. Operation not complete 


Description: The processor has not generated a memory operation within 
50-100 us andis notin DIS. 


SYSOUT: OP NOT COMPLETE AT XXXXXX 
Action: Abort 
15. Parity 


Description: A parity error has been found in either the word referenced 
or the other word of the memory pair. 


SYSOUT: PARITY AT XXXXXX 
Action: Abort 
16. Timer Runout 
Description: This fault will be generated when the Timer count reaches 
zero, If the processor is in master mode, recognition of 
the fault will be delayed until the processor returns to 
slave mode. 


SYSOUT: (None) 


Action: Dispaicher selects another program for execution 


Faults in Master Mode Programs 


The standard action for several of the faults calls for aborting the program. This is clearly 
not the desired action if the fault occurs ina master mode program. In sucha case, the 
operator will be informed so that he may call a Product Service man who will arrange to 
localize the hardware problem via tests. After the hardware has been repaired, a system 
restart will be initiated. 
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DISPATCHER (GEDISP) 


Purpose and Method 


The purpose of GEDISP is to try to keep as many system components as possible in simultane- 
ous use. It does this by first allowing one program to be executed, then another, etc., so that 
the I/O operations required by the different programs can be overlapped as much as possible. 


In selecting a program for execution, GEDISP gives preference first to master mode programs 
and then to slave programs. Within each of these categories, the relative urgency of the 
programs is considered. However, GEDISP will not select a program which just relinquished 
control or for which the interval timer just ran out, unless no other program is ready for 


execution. 


Entry into GEDISP 


Entry into GEDISP takes place whenever a master mode program completes its task and has 
nothing further to do at that time, or whenever a slave program has used up the interval of time 
allotted to it by the Dispatcher, or when any program requests to be roadblocked or to re- 
linquish control. In addition, GEDISP will assume control, following the acceptance of an 1/O 
request by GEIOS, whenever a master mode program is ready for execution, provided that the 
I/O request was not given during a courtesy call. 


GECOS 
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3. GEFLOW CONTROL CARDS 


INTRODUCTION TO GEFLOW 


The GEFLOW module of the Comprehensive Operating Supervisor is concerned with the 
preparation of programs for execution, the initiation and termination of execution, and the 
conversion of standard outputs to printed or punched form. To perform these functions, 
GEFLOW is divided into four sections: 


1. GEIN--Transcribes program inputs to drum, collects control information, 
and organizes inputs for convenience at execution time 


2. GEALOC--Determines availability of hardware components for each program 
and initiates execution as sufficient components are found 


3. GETERM--Removes programs from the computer, records accounting 
information, releases cuimpoucits, and compacis memory 


4, GEOUT--Transcribes outputs writtcn ou SYSOUT (the standard system output 
file) into printer output or punch cards 


Each section of GEFLOW, although independent in function, interfaces with the other sections. 
Frequently referenced sections reside permanently in master memory, while less frequently 
used sections exist as temporary overlays, being called from drum or disc storage when 
needed. 
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USE OF CONTROL CARDS 


All job identification and file control information required for execution of the job is on control 
cards in the input deck. The user, through these control cards, can instruct the Operating 
Supervisor in the execution of the individual activities of his job. This section explains the 
purpose and format of all control cards used by the Operating Supervisor. 


All control cards pertaining to an activity must immediately precede the data for the activity, 
with the control card defining the activity being the first such card. All control cards are 
identified by a $ incolumn 1. Except for the $ symbol, the label field must be blank. The 
control field begins in column 8. Operands, when present, begin in column 16 and are 
separated by commas. No imbedded blanks are permitted. (A blank terminates the field 
definition.) 


The Basic Input Deck 


The first control cards in any input deck are used for identification, These cards are SNUMB, 
the job identifier, and IDENT, which contains basic accounting information. A discussion of 
these control cards follows: 


SNUMB 


$ tSNUMB Job Identifier, Urgency 


The SNUMB control card is the first card of every job. This card is supplied by the operations 
section at every installation. In the operand field, the first entry is from one to five characters 
long and is called the "job identifier." The job identifier is used by the Operating Supervisor to 
identify the job internally. The second entry is the "urgency."’ This entry is also supplied by 
the installation and determines the internal priority of the job. If urgency is omitted, a value of 
1 is assumed. For a discussion of urgency, consult the System Summary pages 3 and 4. 


IDENT 


The IDENT contro! card is used to supply accounting information. At least one IDENT card 
must immediately follow the SNUMB control card. However, each activity may be preceded 
with an IDENT CARD; or an IDENT card may be used for a series of activities, in which case 
all accounting information for these activities contains the same identification information. 
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The operand field is defined by the individual installation. An accounting routine is available 
from the General Electric Computer Department for use at the option of the installation. This 
routine uses the following operand entries: The first entry is a 5-character account number. 
The second entry is the requestor's identification and may not exceed 12 characters. The third 
entry specifies the type of run (compile, sort, debug, etc.). The fourth entry may contain 
additional comments, 


pe 
a 
[ony 


OBJECT 


The OBJECT control card is used to identify the beginning of an object program or subprogram 
in the input sequence of a job. This control card is produced by the Assembler as the first card 
of an object program or subprogram deck. 


DKEND 1 8 16 


The DKEND control card is used to identify the end of an object program or subprogram in the 
input sequence of a job. It is produced by the Assembler as the last card of an object program 


ul subprugrani deck, 
EXECUTE | 8 16 


I 
|EXECUTE| 


On 1, On2...On6 


The EXECUTE control card is used to request the loading of object programs, This card must 
appear after all subprograms to be executed but before their data, Effectively, the EXECUTE 
control card requests the Operating Supervisor to call the Loader, which then loads all sub- 
programs of the activity. The entries in the operand field specify variables which may be sens- 
ed during program execution. The sense switches 1 through 6 may be turned on this way; if not 
noted,the switches are assumed to be off. 


LIMITS 1 8 i6 


i 
$ LIMITS ,|Time, Storage 1, Storage 2, 
l 


|Print Lines 
1 


The LIMITS control card is used with each program to be executed and appears immediately 
behind the EXECUTE control card for that activity. The standard limits of system programs 
may also be modified using a LIMITS control card. 
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The operand field of the LIMITS control card contains four entries. The first entry specifies 
the maximum run time for the activity, beyond which the job is terminated. The unit of time is 
a decimal integer denoting hundredths of hours, If an activity calls upon a system program 
(such as, an object program calling SORT). this processing time must be included in the time 
estimate for the activity. 


The second entry denotes the maximum storage requested for the running of the program. The 
units of storage are decimal digits representing the number of words desired. (Actual memory 
allocation is made in multiples of 1024 words.) The smallest request accepted by GECOS 

is 2048 words. 


The third entry specifies the minimum storage which can accommodate the program if the 
maximum is unavailable at the time of memory allocation. If the minimum storage is equal to 
the maximum storage, the third entry may be omitted (however, the separating comma must 
be present). 


The fourth entry specifies the maximum number of lines to be written on SYSOUT during 
program execution for later printing. 


This control card is not required for system programs such as FORTRAN or COBOL, since 
their LIMITS are predefined. 


In a "compile and go" or "assemble and go" operation, the LIMITS card defined for the run by 
the programmer should pertain only to the anticipated execution of the user's program and not 
to the compilation or assembly process. If an installation desires, it may define a standard 
set of limits which is supplied automatically by the Operating Supervisor when the LIMITS card 
is omitted. 


ENDJOB 


The ENDJOB control card is the last card of every job. When this card is encountered by 
GEIN, the job being processed becomes a candidate for allocation and execution, provided 
errors were not detected during processing by GEIN. If errors are detected, they are noted 
on the console typewriter as they occur. GEIN completes the processing and the entire job is 
deleted without allocation. 


An example of a basic input deck is shown below: 


$ SNUMB 00401 
$ IDENT 00123, JOE SMITH, DEBUG, TEST FOR PAYROLL 
$ OBJECT 
-oee-- } object deck 
$ DKEND 
$ EXECUTE 
$ LIMITS 10, 3000, , 40 
$ ENDJOB 
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The LIMITS card specifies that the run will operate up to 10 hundredths of an hour, needs a 
maximum and minimum of 3000 decimal words of memory and has a maximum of 40 lines of 
printer output to be passed to SYSOUT. Note that, since the desired maximum and minimum 
memory are the same, the third field of the operand may be omitted so iong as the fieid- 
defining comma remains. 


Assembler and Compiler Call Cards 


Each of the following compiler or assembler call cards offers several options pertaining to the 
output of either the assembler or the compilers. These options are specified with designators in 
the operand field of the call cards. If no designators are specified, the Operating Supervisor 
will assume certain standard options depending on which call card was used. The standard 
options may be changed by any installation. In the following discussion of each of these control 
cards, the standard options will be underlined. 


GMAP j : io 


| 

$ | GMAP LSTOU, NDECK, NCOMDK 
| 
I 


The GMAP control card is used to call the Macro Assembler. This control card must precede 
the source cards of each program or subprogram to be processed. The operand field specifies 
the system options and these may be listed in any desired order. 


The options available with the Assembler are as follows: 


LSTOU A listing of the output will be prepared. (For a detailed discussion 
of the output listing, consult Chapter 3 of the Programming Reference 
Manual, CPB-1004A.) 


NLSTOU No listing of output will be prepared. 
DECK A binary object program deck will be prepared as output. (Fora 


detailed discussion of the binary output deck, consult Chapter 3 of 
the Programming Reference Manual, CPB-1004A.) 


NDECK __ No binary object program deck will be prepared. 
COMDK A compressed deck of the source program will be prepared. (Fora 


detailed discussion of compressed decks, consult Chapter 3 of the 
Programming Reference Manual, CPB-1004A.) 


NCOMDK No compressed source deck will be prepared. 


FORTRAN 1 8 16 


I 
(FORTRAN LSTIN, NLSTOU, NDECK, NCOMDK, NSTAB 
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The FORTRAN control card is used to call the FORTRAN compiler. This control card must 
precede the source statements of each subprogram to be processed. The operand field 
specifies the system options. They may be listed in any desired order. 


The options available with FORTRAN are as follows: 


LSTIN A listing of the input will be prepared. (For a detailed discussion of 

the input listing, consult the FORTRAN IV Reference Manual, CPB-1006.) 
NLSTIN No listing of the input will be prepared. 
LSTOU A listing of the output will be prepared. (For a detailed discussion of 

the output listing, consult the FORTRAN IV Reference Manual, CPB-1006. ) 
NLSTOU No listing of output will be prepared. 
DECK A binary object program deck will be prepared. (For a detailed 


discussion of the binary object deck, consult Chapter 3 of the 
Programming Reference Manual, CPB-1004A.) 


NDECK No binary object program deck will be prepared. 
COMDK A compressed deck of the source program will be prepared, (Fora 


detailed discussion of compressed decks, consult Chapter 3 of the 
Programming Reference Manual, CPB-1004A.) 


NCOMDK No compressed source deck will be prepared. 
STAB A symbol table to be used by GELOAD for DEBUG statements will be 


produced in the object deck. (For a detailed discussion of symbol 
tables, consult the General Loader Manual, CPB-10084A.) 


NSTAB No symbol table will be produced. 


COBOL 1 8 16 


! | 
ICOBOL , LSTIN, NLSTOU, NDECK, NCOMDK 


The COBOL control card is used to call the COBOL compiler. This control card must precede 
the source statements of each subprogram to be processed. The operand field specifies the 
system options which may be listed in any desired order. The options available with COBOL 
are as follows: 


LSTIN A listing of input will be prepared. 
NLSTIN No listing of input will be prepared. 
LSTOU A listing of output will be prepared. (For a detailed discussion of 


output listings, consult Chapter 3 of the Programming Reference 
Manual, CPB-1004A.) 


NLSTOU No listing of output will be prepared. 
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DECK A binary object program deck will be prepared as output. (Fora 
detailed discussion of binary decks, consult Chapter 3 of the 
Programming Reference Manual, CPB-1004. ) 


NDECK No binary object program deck will be prepared. 
COMDK A compressed deck of the source program will be prepared. (Fora 


detailed discussion of compressed decks, consult Chapter 3 of the 
Programming Reference Manual, CPB-1004.) 


NCOMDK No compressed deck of the source program will be prepared. 


In the following example of an input deck, the GMAP control card does not specify any operand 
options. This means that the programmer is satisfied with the system standard options (an 
output listing only). However, on the FORTRAN control card, a listing of output, a compressed 
deck, anda symbol table are specified. From the STAB option, it can be assumed the 
FORTRAN programmer wishes to use the Loader DEBUG option at a later date. 


$ SNUMB 00A12 
$ IDENT 00174, JOE SMITH, COMPILE, PAYTEST 
$ GMAP 
“____ ) source cards 
ro I a tare AW? TORN MmAmnaATI YY oma TD 
y A AE eB ra dude, wate ds, Wasi 


Soe } source cards 


EXECUTE 
LIMITS 4, 2000, , 20 
ENDJOB 


th A SH 


NOTE: The LIMITS control card includes the time for the execution only, not for 
the assembly and compilation, since that time is predefined. 


File Control Cards 


File control cards define file information pertaining to a program to be executed. When calling 
upon a system program, such as FORTRAN or COBOL, file cards need not be included. In this 
situation, the file information is provided by GECOS. However, file substitution can be made in 
a system program for an individual run by the inclusion of a ''file'' card whose file code is 
identical to that for the file to be replaced. 


Within a control sequence, file cards must follow the control card that defines the activity and 
precede any data cards associated with the activity. File cards associated with the execution of 
an object program must appear behind the EXECUTE control card for the activity. 
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The control field defines the type of unit involved. 


The operand entries vary somewhat between file card types. The entries common to all file 
cards are described below. 


File Code - A two character designation which is the code assigned by the programmer to 
uniquely identify a given file within his program. Refer to the GESERV section of this manual 
for a discussion of file codes. 


Logical Unit Designator - All file control cards contain in their operand fields (in addition to a 
file code) a two or three character designation of the primary channel and unit assigned to the 
file. The first character is the symbolic channel letter. All files designated with the same 
type and letter are assigned to the same channel. The letter A is used to specify the first 


available channel of a peripheral type, the letter B for the next channel, etc. If only one type 
peripheral channel is present in any 625/635 system, the letter A must always be used, 


The second portion of the logical unit designator is numeric and is the unit identifier. The nu- 
merals have no specific meaning except that, for any one channel, the quantity of different 
numerals is equal to the number of units to be assigned to that channel. When using tape files, 
identical channel and unit characters within the same activity are assumed to be multifile units. 


The last character of the logical unit designator is used to indicate the disposition of the unit 
following execution of the current activity. Itis referred to as the disposition code. The 
disposition code conveys the intelligence to GECOS that it needs to accomplish such things as: 


1. Assigning a physical device containing a file created in a prior activity to the 
proper input file for the current activity. 


2. Insuring that a magnetic tape file to be removed from the computer is rewound with 
standby so that it may not be inadvertently reallocated and written upon. 


3. Allowing a magnetic tape which has been written on to be temporarily dismounted 
and its "write inhibit’ ring pulled, the tape to be then remounted and read. 


4, Informing the system when a file is to be released for use by other activities/jobs. 


The specific disposition codes for magnetic tape files are described below. 


Code Meaning Action Taken at Activity Termination 
iS) Save 1, No specific termination action. 


2. Assign this unit to files with the same channel unit 
designator in subsequent activities of this job. 


Cc Continue 1. Rewind using ''rewind and standby". 
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Code Meaning Action Taken at Activity Termination 


Cc Continue 3. Inform the operator to remove the "write inhibit" 
(cont) ring and remount the tape. 


4. Assign this unit to files with the same channei unit 
designator in subsequent activities of this job. 
D Dismount 1. Rewind using "rewind and standby’'. 
2. Issue dismounting instructions. 
3. Assign files with the same channel unit designator 
in subsequent activities to any available unit. 
R Utility 1. Rewind using "rewind" instruction. 
2. Do not issue dismounting instructions. 


3. Make available for assignment as utility tape. 


Disposition codes for non-magnetic tape files are as follows: 


Code Meaning Action Taken at Activitv ‘Permination 
S Save 1. Assign this device to files with the same channel unit 


designator in subsequent activities of this job. 
Cc Continue 1. Do not apply to nonmagnetic tape files. 
D Dismount 
2. Are interpreted as U if present. 


R Utility 1. Make available for use by another activity/job. 


TAPE 


| 
Symbolic Example $ | TAPE File Code, Logical Unit Designator, 
| j Secondary Logical Unit Designator, 
y ‘File Serial No. , Reel Sequence No., 
File Name 


Actual Example $ TAPE AB, A1S,, 24, 0001, BIGFILE 
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The operand field contains, besides the file code and logical unit designator, the following 
entries. 


Secondary Logical Unit Designator - Any non-blank combination of six or less characters. 
When this entry is present, a secondary unit will be assigned to the file on the same 
channel as the primary logical unit. 

File Serial Number - (Refer to the File and Record Control Manual), 


Reel Sequence Number - (Refer to the File and Record Control Manual). 


File Name - Any combination of twelve or less characters which represents the 
literal name given to this file for external identification. 


PRIN TER- CARD READER-CARD PUNCH-PERFORATED TAPE-CONSOLE TYPEWRITER 


1 8 16 


{ 
Symbolic Example | PRINT | File Code, Logical Unit 
| , Designator 
I I 


Actual Example $ PRINT BA, Al 


The control field contains one of the following words, left-justified: PRINT (High-Speed Printer), 
READ (Card Reader), PUNCH (Card Punch), PPT (Perforated Tape Reader/Punch, TYPE (On- 
line Console Typewriter). 


The operand field contains the file code and logical unit designator. 


The file control card for the DISC or DRUM is different from the tape file control card in that 
the first character of the logical unit designator is the symbolic channel-unit designator. 
Therefore, for a GE-625/635 with a peripheral configuration consisting of one DSU controlling 
four file units, the letter A is used to specify the first available channel-unit, B the second, 

C the third, and Dthe fourth. For a configuration consisting of two DSU's each controlling four 
file units, the letters A-H would be used. 


The second portion of the logical unit designator is numeric and is the file identifier. The 
numerals have no specific meaning other than, for any one channel-unit, the quantity of different 
numerals is equal to the number of files to be assigned to that channel-unit. 


There is a restriction on the use of the logical unit designator for DSU or drum files. Once a 
specific file has been declared a ‘'saved"' file, the designator used for that file may not be used 
to designate another different file within a job. 


GECOS 


GE-GOO SERIES 


-60- 


DRUM-- DISC 


i & i6 


| I 


| 
Symbolic Example $ | DISC | File Code, Logical Unit 
y | Designator, Access, Label, 
: Status 
LT 
Actual Example |$ | DISC , C1, Al, 4R 


Access - Linked files are designated by the number 3840-word blocks allocated to the 
file followed by the letter L. Random files are designated by number of 3840-word blocks 
allocated to the file followed by the letter R. 


See GESERV chapter, page 29, for a discussion of Linked and Random files. 


If the programmer wishes to access a drum or DSU file that has been allocated and saved by a 
previous activity of the job, he is not permitted to alter the type--link/random--or the size of 
the allocated file from that which was specified on the "save" file card, 


Multifile DSU and DRUM files arc not permitted. The following is an example of this illegal 
combination, both tiles are requested in the same activity. 
Disc AB, Al, SL 


Dise AC, Al, 3L 


NTAPE 


t 
| NTAPE 


Symbolic Example File Code, Channel Designator, 
i ; Number of Tapes 
Actual Example $ !' NTAPE 'U1, A, 3 


The $ NTAPE control card requests a number of utility tapes to be assigned to the tape channel 
specified. File codes are assigned by GECOS, beginning with the file code specified and 
increasing by one (binary addition) for each tape assigned. 


File Code - The first tape assigned will be given this file code; each subsequent tape will 
be assigned a file code equal to one (1) plus the file code of the previous tape. 


Channel Designator - This entry specifies the symbolic tape channei on which the tapes 
are to be allocated. 


Number of Tapes - This entry specifies the number of utility tapes to be allocated. 
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An example of an input deck using file control cards is shown below: 


$ SNUMB 10023 
$ IDENT 3001B, JOE SMITH, UPDATE DEBUG 
$ OBJECT 
aoe--- object deck 
$ DKEND 
$ EXECUTE 
$ LIMITS 8, 6000, , 700 
$ DRUM Al, B48, R4 
$ TAPE AB,AI1R,,123,1, FILEA 
$ TAPE AC,BIR,,143,1, FILEB 
$ ENDJOB 


This example shows an object program running 8 hundredths of an hour, using 6000 words of 
memory and 700 lines of printer output written on SYSOUT. The files used are a permanent 
drum file, and two utility tapes. 


DATA 1 8 16 


DATA 


File Code 


The $ DATA control card signifies that the cards or card images that follow constitute a file 
which will be referred to by the file code supplied in the operand field. All cards following the 
$ DATA control card up to the next $ control card are written onto a temporary linked drum file. 
Upon termination of the activity for which the file was created, the file and all references to it 
are removed from the computer. 


The $ DATA control card may be used to place as many files as desired on the drum to be 
referenced at execution time. However, if the programmer does not wish to use the $ DATA 
control card he may let GEIN create a single data file for him by placing his data cards after 
all other cards of the activity. In this case the created file will be assigned file code I* 
automatically. 
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SYSOUT ! 8 16 
I 
$ 1SYSOUT , File Code 


The SYSOUT controi card is used to assign output files to the major system output unit 
SYSOUT. This control card may be used only for files that are normally destined for printing 
or punching as output files. The usual way to place output files on SYSOUT is by assigning 
them to the P* file. However, for certain problems such as debugging when a normally long 
output file contains only test output, the programmer may wish to avoid the time and expense 
of mounting, dismounting and using additional tape handlers for short test runs. In this case 
the programmer substitutes a SYSOUT control card for each file control card in his input 
deck that he wishes to place on the SYSOUT unit. 


An example of using $ SYSOUT and $ DATA control cards is shown below: 


$ SNUMB 0001A 
$ IDENT 00010, JOE SMITH, DEBUG 
$ OBJECT 
ee 
Wiehe tet » ohect deck 
es ) 
$ DKEND 
$ EXECUTE 
$ LIMITS 6, 6000, , 700 
$ DATA A2 
mace data cards 
$ SYSOUT ZZ 
$ ENDJOB 


The example shows a LIMITS of six hundredths of an hour, with 6000 words of core used and 
700 lines of output to be written on SYSOUT. The data cards will be stored on the drum with 
the file code of A2. The normal output file (ZZ) will appear on the SYSOUT file. After 
debugging, the $ SYSOUT card will be replaced by a regular file control card. 


Other Control Cards 


SELECT 


| 
$ iSELECT |Medium, Label 


The SELECT control card is used to access programs, data and/or control cards that have 
been stored on the disc or drum in standard system format. Upon detection of a SELECT 
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control card, GEIN (input media conversion) will immediately begin reading and interpreting 
card images from the file specified by the contents of the operand field. The selected file will 
be used in lieu of the normal input device until its end-of-file is encountered, The input source 
will then revert back to the normal input device and continue processing the input stream. The 
operand field contains two entries. The first entry is either the word DISC or DRUM. The 
second entry is the label identification attached to the disc or drum file when the catalog entry 
was made for this file by the disc or drum maintenance programs. The label operand is from 
one to twelve characters in length and must refer to a permanent file. 


The information called from the drum may consist of any legitimate program input, including 
control cards. However, the programmer may change any control card by including a replace- 
ment in the input deck after the SELECT card, GEIN replaces the $ control cards called from 
the drum with any $ control cards in the input deck that have identical file codes. 


$ SNUMB 0001B Subprogram called from the drum: 

$ IDENT 00141, JOE SMITH, RUN B 

$ OBJECT $ OBJECT 
elated \ object deck ------ ; object deck 

$ DKEND $ DKEND 

$ EXECUTE $ EXECUTE 

$ LIMITS 5, 4000, , 100 $ LIMITS 5, 1000, , 40 

$ TAPE AB, A1S, ,123,1, FILEB $ TAPE AB, A1D, , 99999 
wacn-- $ TAPE BB, A2D, , 99999 
eeeern | data cards 

$ SELECT DRUM, RUNTB 

$ TAPE AB, A1D, ,123,1, FILEB These file control cards will replace 

$ TAPE BB, A2D, 234,1, ENDB those on the drum for files AB and BB. 

$ ENDJOB 


In this example, the object subprogram saves an output tape (AB) which the subprogram 
(RUNTB) from the drum uses as input. Output from the selected drum program (RUNTB) is 
saved on tape ENDB. 


UPDATE ll 8 16 


I I 
| UPDATE | 


The UPDATE control card is used when supplying alter input to a compiler or assembler. In 
the input sequence for a job, the UPDATE control card and associated alter statements must 
follow and be contiguous to the source program to which the alter statements apply. 


For a complete description of the program alteration function consult the General File and 
Record Control Manual, CPB-1003B. 


GE-SOO SERIES GECOS 


-64- 


An example of using the UPDATE control card follows: 


SNUMB 
IDENT 
GMAP LSTOU, COMDK 


AAA 


aeeee- 54 compressed source deck 


ALTER ny, My 


ALTER ng,M9 


ng, mg 


EXECUTE 
LIMITS 
ENDJOB 


PRA FF PP RW 
> 
f 
4 
ta 
Bs) 


The programmer may call for an updated object deck and an updated compressed source deck 
incorporating alter statements. This function is accomplished by specifying the DECK and 
COMDKE options when an assembly cor compilation is being processed using associated alter 


statements. 


16 


he 
[os) 


COMMENT 


I 
\COMMENY Any Comments 


The COMMENT control card is used by the programmer to communicate to the operator 
through the on-line typewriter. The entire contents of columns 16-72 will be typed by GECOS 
immediately preceding execution of the activity in which the COMMENT cards occur. Note: 
This card should be used with caution. The time to type the comment could exceed the 
execution time of the activity. If this happened frequently the entire system could be waiting 
on the typewriter. 
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INCODE | 8 16 


i 
; BCD Card Code 
I 
{ 


The INCODE control card indicates that the following BCD input cards must undergo character 
transliteration from the character set specified on the INCODE card to the internal binary 
representation of the GE-635 Standard Character Set. All BCD cards following the INCODE 
card and preceding the next control card will undergo transliteration. (See Figure 6, page 77.) 


The operand field contains the mnemonic which identifies the character set used in punching 
the input cards, The mnemonic IBMF designates the IBM FORTRAN character set, while the 
mnemonic GE225 designates the GE-225 character set. The IBM Business (or EAM) character 
set is a subset of the GE Standard Set and hence is not an operand option. 


An example of the use of the INCODE control card follows. 


SNUMB 

IDENT 

FORTRAN 

INCODE IBMF 


RAAAK 


woonn- source cards in IBM FORTRAN character set 


EXECUTE 
LIMITS 
ENDJOB 


AAA 
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Control Cards Used by the General Loader (GELOAD) 


stream for Loader use. 


Many $ control cards 
Many $ co i cards 


OPTION 
USE 


WATTDNY 
GINGAIVI 


EQUATE 
LOWLOAD 
LIBRARY 
OBJECT 
DKEND 
DUMP 
LINK 


PP LAR LA A 49 1A HH 


LINK 


control cards are 


atu 


The $ LINK control card is used by the programmer for specifying overlay segments to pro- 


Biadlus, 


Upon tecuguizing a $ LINK control card , 


GEIN will assign a file (file code H*) upon 


which the Loader will save the overlay segments specified by the control card, The $ LINK 


control card is then passed on to the Loader input file (file code R*). 


The Loader uses the 


$ LINK cards and the overlay segment file during its execution, 


A complete discussion of the Loader $ control cards and their formats may be found in the 


General Loader Manual, CPB-1008A. 
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GECOS 


APPENDIX 


MAJOR STATUS AND SUBSTATUS CODES 
With Explanations and Error Recovery Procedures 


INTRODUCTION 


The Status Return Pointer field of the Return Word (see page 38) indicates to the programmer 
the address of the two status return words which carry back information supplied by GEIOS on 
the termination of the current input/output request. The first of these status return words 
contains a Major Status field (bits 2-5) and a Substatus field (bits 6-11), which serve to identify 
the nature of the termination of the request. 


Those status returns listed with an * in this Appendix are the only ones that a user program can 
expect to see in the status return words, unless it issues a Request Status (REQS) or a Reset 
Status (RESS) command. If the program issues an REQS or an RESS command, it must be 
prepared to receive any of the status/substatus conditions listed herein. No error recovery 
action is performed when either an REQS or an RESS is issued. 


r ah) a ee ceo Bs Syl aa eh Seaga ds iniede bois Rates: Sun elon, Sey gargtin de afiag Moats» Scag Rt 23 ptt MMe oe Se EY a a 
dash Ads MOV SC Willii Vda 2eeyrvedr y Av tsyii 1O LAM II, Appa Ups fale Cd ds Staviolii yd ait typoeu alu 


written on SYSOUT for later processing and statistical analysis. 


Throughout this Appendix, wherever it states under "Action Taken by GEEPR" that the operator 
is given the option of aborting the program, this implies that he will also take any applicable 
action necessary to initiate servicing of the malfunctioning hardware. 


GECOS 
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CARD READER 


PRUNE ee, Re a ee 


Major Status: *Channei Ready (0000) Substatus: None (000000) 


Meaning of Status Return: 


if this status is received as an iniliation interrupt in response to REQS or RESS, the card 
reader is ready to accept a new command. 


If this status is received as a termination interrupt, it indicates the command execution 
was error free and the card reader is ready to accept a new command. 


Action taken by GEEPR: 


On Initiation and Termination: Status returns are passed back to user program. 
Major Status: Attention (0010) Substatus: Hopper/Stacker Alert (XXXXX1) 


Meaning of Status Return 
a) input card hopper is emptv. 
b) Output card stacker is full. 


c) Both a) and b) exist. 


Action taken by GEEPR: 


On Initiation: A message is typed to the operator instructing him to place more cards 
in the input hopper or remove cards from the output stacker. When the attention condition 
has been corrected and the card reader is in 'ready,'' the previously rejected command 
will be reissued. 


On Termination: The first word of the card image (columns 1-6) is scanned in memory. 
If this word contains the Standard End-of-File card format (***EOF in columns 1-6) an 
End-of-File major status (0100) is returned to the user. If the word in memory is not of 
this format, a Channel Ready major status (0000) is returned. If the last card read was 
not an End-of-File card and the program gives another card read command, this will 
result in an initiation interrupt. The operator will then be able to either refill the input 
hopper with the remainder of the input deck, or place the End-of-File card, which he 
previously forgot, in the input hopper resulting in an End-of-File major status being 
returned to the user. 
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CARD READER (Continued) 
Major Status; Attention (0010) Substatus: Feed Alert (XX1 XXX) 


Meaning of Status Return: 


A new card failed to feed from the input hopper within the prescribed time. 


Action taken by GEEPR: 


On Termination: No manual backspacing is required. A message is typed to the 
operator giving him the following options: 


a) Take corrective action and then retry the command, or 
b) Call in a hardware test routine, or 


c) Abort the program, or initiate a rollback procedure. 


Major Status: Attention (0010) Substatus: Manual Halt (XXXX1X) 


Meaning of Status Return: 


The operator has depressed the HALT switch. He must depress the OPERATE/RESET 
to resume normal operations. 


Action taken by GEEPR: 
On Initiation: The initiation of the command will be deferred. It will be executed when 


a special interrupt is received as a result of the operator depressing the OPERATE/RESET 
switch. 
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CARD READER (Contimed) 
Major Status: Attention (0010) Substatus: Last Batch (XXX1XxX) 


Meaning of Status Return: 


This substatus will never be seen by the user program when GEEPR is used. It arises 
from one of the following conditions: 


a) The input card hopper has gone empty while the LAST BATCH switch was on, or 


b) While the HOPPER/STACKER ALERT switch was on, the operator depressed the 
LAST BATCH switch and a REQS/RESS command was issued. 


Action taken by GEEPR: 


On Initiation and Termination: This substatus is treated exactly as if a Hopper/Stacker 
Alert substatus had been received, 


Major Status: Attention (0010) Substatus: Card Jam (X1XXXX) 


Meaning of Siaius Rewrn: 
A card's trailing edge did not arrive at a photocell within the prescribed time period after 
its leading edge had passed this photocell. (After about 2 seconds following detection of 


this condition, the C/R will begin to cycle down and power will be removed from the 
device. ) 


Action taken by GEEPR: 


On Initiation: No manual backspacing is required. A message is typed to the operator 
giving him the following options: 


a) Take corrective action and then retry the command, or 

b) Callin a hardware test routine, or 

c) Abort the program, or initiate a rollback procedure. 

On Termination: Manual backspacing is required. A message is typed to the operator 
giving him the following options: 

a) Take corrective action, manually backspace the device, and then retry the command, or 
b) Call in a hardware test routine, or 

c) Abort the program, or initiate a rollback procedure, 


CARD READER (Continued) 


Major Status: Attention (0010) Substatus: Read Alert (1XXXXX) 


Meaning of Status Return: 


The actual time required for the card to pass through the read station was not within the 
acceptable time range. 


Action taken by GEEPR: 


On Termination: No manual backspacing is required. A message is typed to the 
operator giving him the following options: 


a) Take corrective action and then retry the command, or 
b) Call in a hardware test routine, or 


c) Abort the program, or initiate a rollback procedure. 


Major Status: Data Alert (0011) Substatus: Transfer Timing Alert (00000X) 


Meaning of Status Return: 
The IOC did not receive (read) data characters at a rate compatible with the transfer rate 
of the system. 

Action taken by GEEPR: 


On Termination: Manual backspacing is required. A message is typed to the operator 
giving him the following options; 


a) Take corrective action, manually backspace the device, and then retry the command, or 
b) Call in a hardware test routine, or 


c) Abort the program, or initiate a rollback procedure. 
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CARD READER (Continued) 
Major Siatus:* Data Aiert (6011) Substatus: Validity 


Meaning of Status Return: 


During a peat Card Hollerith command a character was recognized as not being a valid 


character (See Figure 6, Gencral Electric Character Set). An ignore character (octal 


17) is automatically stored in the memory position of the invalid “character. The re- 
mainder of the card is read and stored normally. 


Action taken by GEE PR: 


On Termination: Data Alert major status (0011) with Validity Check substatus 
(000010) is passed back to the user program. 


Major Status: End of File (0100) Substatus: None (000000) 


Meaniny of Status Return: 


rhe input hopper has gone empiv and tie last card read was an END OF TILE card, This 
card has the following format: 
Col. 123456 
* *K *K E O FEF 
Action taken by GEEPR: 
On Termination: The End of File major status (0100) is passed back to user. 
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CARD READER (Continued) 


Major Status: Command Reject (0101) Substatus: None (000000) 


Meaning of Status Return: 


The received command is being rejected because it is of an unacceptable configuration or 
has a parity error. 


Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 
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Standard GE-Internal Hollerith Standard GE-Internal Hollerith 
Character Machine Character Machine Card 
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Figure 6. Standard Character Set 
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CARD PUNCH 
Major Status: * Channel Ready (0000) Substatus: None (000000) 


Meaning of Status Return: 


If this status is received as an initiation interrupt in response to REQS or RESS, the card 
punch is ready to accept a new command. 


If this status is received as a termination interrupt, it indicates the command execution 
was error free and the card punch is ready to accept a new command. 
Action taken by GEEPR: 


On Initiation and Termination: Status Returns are passed back to user program. 


Major Status: Attention (0010) Substatus: Hopper/Stacker Alert (OXXXX1) 


Meaning of Status Return: 
a) Input card hopper is empty. 
b) Output card stacker is full. 


c) Botha) and b) exist. 


Action taken by GEEPR: 


On Initiation: No manual backspacing is required, A message is typed to the operator 
informing him of the condition, The interrupted command will be reissued as soon 
as the attention condition is cleared. 


On Termination: This condition is ignored and GEEPR returns a Channel Ready 


status to the user because this I/O operation was completed normally. This attention 
condition will be detected as an initiation interrupt on the next I/O request to this device. 
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CARD PUNCH (Continued) 


Major Status: Attention (0010) Substatus: Manual Halt (OXXX1X) 


aay 


Meaning of Status Return: 


The operator has depressed the "HALT" switch. He must depress the OPERATE/RESET 
to resume normai operations. 


Action taken by GEEPR: 


On Initiation: GEEPR will resume normal operation when the attention condition is cleared 


On Termination: This condition is ignored and GEEPR returns a Channel Ready 
status to the user because this I/O operation was completed normally. This attention 


condition will be detected as an initiation interrupt on the next I/O request to this device. 


Major Status: Attention (0010) Substatus: Chadbox Full (0OXX1XX) 


Meaning of Slalus Returu: 


Chad is the waste material resulting from a card being punched. When the receptacle for 
these pieces of chad is full, this status is returned and the operator must empty the 
chadbox before normal punching can be resumed. 


Action taken by GEEPR: 


On Initiation: No manual backspacing is required, A message is typed to the operator 


informing him of the condition, The interrupted command will be reissued as soon 
as the attention condition is cleared, 


On Termination: This condition is ignored and GEEPR returns a Channel Ready 


status to the user because this I/O operation was completed normally. This attention 


condition will be detected as an initiation interrupt on the next I/O request to this 
device. 
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CARD PUNCH (Continued) 
Major Status: Attention (0010) Substatus: Feed Alert (0X1 XXX) 


Meaning of Status Return: 
A card has failed to feed from the input hopper into the card punch mechanism. The card 
currently being punched is completed normally. 

Action taken by GEEPR: 


On Initiation: No manual backspacing is required. A message is typed to the operator 
giving him the following options: 


a) Take corrective action and then retry the command, or 

b) Call in a hardware test routine, or 

c) Abort the program, or initiate a rollback procedure. 

On Termination: This condition is ignored and GEEPR returns a Channel Ready 


status to the user because this I/O operation was completed normally. This attention 
condition will be detected as an initiation interrupt on the next I/O request to this device. 
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CARD PUNCH (Continued) 


Major Status: Atiention (0016) Substatus: Card Jam (01XXXX) 


Meaning of Status Return: 
One or more cards were improperly loaded in the input hopper or a card has failed to feed 
at the proper time from one station to another. The card currently being punched will 
immediately be terminated and will not be completed normally. (After about 2 seconds 
following detection of this condition, the C/P will begin to cycle down and power will be 
removed from this peripheral. ) 


Action taken by GEEPR: 


On Initiation: No manual backspacing is required. A message is typed to the operator 
giving him the following options: 


a) Take corrective action and then retry the command, or 

b) Call ina hardware test routine, or 

c) Abort the program. or initiate a rollback procedure. 

Un iermination: Manual backspacing 1s required. A message is tvped to the operator 
giving him the following options: 

a) Take corrective action, manually backspace the device, and then retry the command, or 
b) Call ina hardware test routine, or 


c) Abort the program, or initiate a rollback procedure. 


Major Status: Data Alert (0011) Substatus: Transfer Timing Alert (000000) or (000XX1) 


Meaning of Status Return: 


The IOC did not send (write) data characters at a rate compatible with the transfer rate of 
the system. 


Action taken by GEEPR: 


On Termination: Manual backspacing is required. A message is typed to the operator 
giving him the following options: 


a) Take corrective action, manually backspace the device, and then retry the command, or 
b) Call in a hardware test routine, or 
c) Abort the program, or initiate a rollback procedure. 
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CARD PUNCH (Continued) 


Major Status: Data Alert (0011) Substatus: Transmission Parity Alert (000X1X) 


Meaning of Status Return: 


Incorrect parity was detected on a data character received from the IOC. This can occur 
only during a "write" operation. 


Action taken by GEEPR: 


On Termination: Manual backspacing is required. A message is typed to the operator 
giving him the following options: 


a) Take corrective action, manually backspace the device, and then retry the command, or 
b) Call in a hardware test routine, or 


c) Abort the program, or initiate a rollback procedure. 


Major Status: *Data Alert (0011) Substatus: Punch Alert (0001 XX) 


Meaning of Status Return: 


A hole count of what is actually punched on the card is compared with the calculated hole 
count. This status indicates the two counts do not agree. 


NOTE: Since this check is made as the card passes from the first post-punch station to 
the second post-punch station at the time this error is detected, a subsequent 


card will be undergoing punching. 


Action taken by GEE PR: 
Data Alert status (0011) with punch alert substatus (0001XX) is returned to the user 
program. The user may use his own recovery action--such as tell the operator to discard 


the last two cards that were punched and then reissue the two commands or he may choose 
to ignore the punch alert substatus. (See NOTE under Meaning of Status Return, ) 
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CARD PUNCH (Continued) 


Major Status: Command Reject (0101) Substatus: None (000000) 


Meaning of Status Return: 
The received command is being rejected because it is of an unacceptable configuration or 
has a parity error. 

Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 
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PERFORATED TAPE READER/PUNCH 
Major Status: *Channel Ready (0000) Substatus: Reader Plugboard No. (XXXXXX) 


Meaning of Status Return: 


When Channel Ready status is returned for any command addressed to the Perforated Tape 
Reader/Punch, the substatus field will contain the 6 bit number which has been wired into 
the Reader Plugboard. If no Reader Plugboard is present a (77). substatus is sent from 
the peripheral. 


Action taken by GEEPR: 
On Initiation and Termination: Status returns are passed back to user program. 


Major Status: * attention (0010) Substatus: Out of Tape (0000X1) 


Meaning of Status Return: 


Either the punch or the reader has run out of tape, or the tape has broken. This condition 
can also occur if the tension is too tight between the punch head and the supply reel. 


Action taken by GEEPR: 
On Initiation and Termination: Status returns are passed back to user program. 


Major Status: Attention (0010) Substatus: Manual Halt (00001 X) 


Meaning of Status Return: 
One or more of the following switches has been actuated: 
a) Manual HALT switch (both punch and reader are inoperable). 
b) READER TAPE LOAD switch (only the reader is inoperable). 
c) PUNCH TAPE LOAD switch (only the punch is inoperable). 
d) ON/OFF LINE switch set to OFF LINE. 


Action taken by GEEPR: 


On Initiation and Termination: GEEPR will resume normal operation when the attention 
condition is cleared. 
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PERFORATED TAPE READER /PUNCH (Continued) 


Major Status: *Data Alert (0011) Substatus: Transfer Timing Alert (00000X) 


Meaning of Status Return: 


The IOC did not send (write) or receive (read) data characters at a rate compatible with 
the transfer rate of the system. 


Action taken by GEEPR: 


On Termination: Since there is no programmed method of backspacing the perforated 
tape reader/punch and since any Data Alert is a termination interrupt and has resulted in 
the movement of perforated tape, GEEPR is unable to perform any recovery for Data Alert 
conditions. GEEPR will return the status to the user program and allow him to initiate 

his own recovery action. 


Major Status: *Data Alert (0011) Substatus: Parity Alert (000X10) 


Meaning of Status Return: 


A parity error has been detected on a data character being read according to the wiring 
of the PARITY HUB on the plugboard. The use of the PARITY HUB will indicate whether 


or not parity is to be checked, and whether parity is to be odd or even. 


While punching, this indicates a parity error is detected on a data character received from 
the IOC. The character in error is not punched. 


Action taken by GEEPR: 


On Termination: Since there is no programmed method of backspacing the perforated 
tape reader/punch and since any Data Alert is a termination interrupt and has resulted 
in the movement of perforated tape, GEEPR is unable to perform any recovery for Data 
Alert conditions. GEEPR will return the status to the user program and allow him to 
initiate his own recovery action. 
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PERFORATED TAPE READER/ PUNCH (Continued) 


Major Status: *Data Alert (0011) Substatus: Punch Tape Warning (0001 X0) 


Meaning of Status Return: 
The take-up reel on the punch is full, or the input reel on the punch has about N feet of 
unused tape remaining. N is variable depending upon the adjustment of a sensing arm. 
The punch tape trailer length (N) should be standardized depending upon the maximum 
record length at an installation, but should never be less than 25 feet. 

Action taken by GEEPR: 
On Termination: Since there is no programmed method of backspacing the perforated 
tape reader/punch and since any Data Alert is a termination interrupt and has resulted in 
the movement of perforated tape, GEEPR is unable to perform any recovery for Data 


Alert conditions. GEEPR will return the status to the user program and allow him to 
initiate his own recovery action. 


Major Status: *End of File (0100) Substatus: None (000000) 


Meaning of Status Return: 
A character wired into the END OF FILE HUB on the reader plugboard has been detected. 
This character will be sent to the IOC unless it has also been wired into the DELETE HUB. 
Action taken by GEEPR: 


On Termination: Status Returns are passed back to user program. 
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PERFORATED TAPE READER/ PUNCH (Continued) 


Major Status: Command Reject (0101) | Subsiaius: Invalid Operation Code (0000X1) 


Meaning of Status Return: 


Either the operation code is unrecognizable or a parity error exists on the opcration code. 


Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


dad) Abort the program. 


Major Status: Command Reject (0101) | Substatus: Invalid Device Code (00001) 


Meaning of Status Return: 


Either the device code is unrecognizable (refers to the punch while the physical system 
contains only a reader) or there is a parity error detected on an otherwise legitimate 
device code. 

Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 
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PRINTER 
Major Status: *Channel Ready (0000) Substatus: None (000000) 


Meaning of Status Return: 


If this status is received as an initiation interrupt in response to an REQS or RESS, the 
printer is ready to accept a new command. 


If this status is received as a termination interrupt, it indicates the command execution 
was error free and the printer is ready to accept a new command. 


Action taken by GEEPR: 


On Initiation and Termination: Status returns are passed back to user program. 
Major Status: Attention (0010) Substatus: Out of Paper (00XXX1) 


Meaning of Status Return: 
This status may be caused by either the detection of torn paper or at the first top of page 
after the paper low condition is detected. 
Action taken by GEEPR: 
On Initiation: Status returns are passed back to user program. (See page 41.) 
On Termination: This condition is ignored and GEEPR returns a Channel Ready 


status to the user, because this I/O operation was completed normally. This attention 
condition will be detected as an initiation interrupt on the next I/O request to this device. 
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PRINTER (Continued) 
Major Status: Attention (6610) Substatus: Manual Hait {OGXX1X) 


Meaning of Status Return: 
Bilher: 
a) The manual HALT switch has been actuated, or 


b) The POWER ON has been actuated while the printer was not in the Power On 
state, or 


c) The printer yoke has been raised from the print hammers. 


This condition is reset manually actuating the "OPERATE/RESET" switch. 


Action taken by GEEPR: 


On Initiation and Termination: Status returns are passed back to user program. 
(See page 41.) 


Major Status: Attention (0010) Substatus: VFU Tape Alert (00X1XX) 


Meaning of Status Return: 
One of the following has occurred: 
a) VFU tape horizontal parity error. 
b) VFU tape is not present. 
c) VFU tape is not properly installed. 
d) Holes are punched in both channel 5 (start automatic slew) and channel 6 (stop 
automatic slew) of the same vertical line position on the VFU tape. 
Action taken by GEEPR: 


On Termination: Status returns are passed back to user program. (See page 41.) 
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PRINTER (Continued) 
Major Status: Attention (0010) Substatus: Check (001XXX) 


Meaning of Status Return: 
One or more of the following has occurred: 
a) Hammer driver fuse failures 
b) Paper slew fuse failure 


c) Incomplete printout detected because not all characters received from IOC have been 
printed 


d) Print wheel out of sequence 


Action taken by GEEPR: 


On Initiation and Termination; Status returns are passed back to user program. 
(See page 41.) 


Major Status: Data Alert (0011) Substatus: Transfer Timing Alert (000011) 


Meaning of Status Return: 
The IOC did not send (write) data characters at a rate compatible with the transfer rate 


of the system. Since data transfer occurs before printing starts, transfer timing alert 
will always be sent with "Alert before printing began'' substatus. 


Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
eaSily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 
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PRINTER (Continued) 


Major Status: Data Alert (0011) Substatus: Alert before printing began (XXXX1X) 


Meaning of Status Return: 
This condition is detected when 


1€ IOC. 


a) Parity error is detected on a print iine data character sent from t 
b) Printer buffer overflow is sensed when more than 136 printable characters (including 


spaces) are received from the IOC before either a slew character or an end data 
transfer signal is received by the printer. 


c) Internal parity error is detected on a character within the internal storage buffer of 
the printer. 


d) A transfer timing alert condition exists. 


Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recuverv is not successful, the operator is 
given the following options: 
al) Keissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 


Major Status: *Data Alert (0011) Substatus: Alert after printing began (XXX1XX) 


Meaning of Status Return: 
This substatus is sent when a parity error has been detected on a data character within 
the printer buffer and physical printing has actually been started. 

Action taken by GEEPR: 


On Termination: Status returns are passed back to user program. (See page 41.) 
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PRINTER (Continued) 
Major Status: Data Alert (0011) Substatus: Paper Low (XX1 XXX) 


Meaning of Status Return: 
A program that uses GEEPR’ need not concern itself with this return, This substatus is 
sent when the printer is about to run out of paper. When this condition is gensed, between 
22 and 26 inches of unused paper still remain. 

Action taken by GEE PR: 
On Termination: This condition is ignored and GEEPR returns a Channel Ready 


status tothe user. At the first top of page, after the paper low cundition is detected, a 
Device Attention - out of paper - status is detected and is passed back te the user program. 


Major Status: Data Alert (0011) Substatus: Slew Alert (X1XXXxX) 


Meaning of Status Return: 


This substatus is sent when two top of page indications (a punch in channel 7 of 
the VFU tape) are sensed within a single slew operation, 


a 
Q) 
irl 
icp 
ae) 
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Action taken by 
On Termination: A message is typed providing the operator with the followi:g options: 
a) Take corrective action and then retry the command, or 
b) Call for a hardware test routine, or 
c) Initiate a rollback procedure, or 


d) Abort the program. 


GE-GOO SERIES GECOS 


-92- 


PRINTER (Continued) 


a\ 


Major Status: *Daia Aiert (6011) Substatus: 


mn 
1 


Meaning of Status Return: 
Paper is slewed to the top of page as a result of a slew command other thin an explicit 
slew-to-top-of-page command. This is often used by a programmer to initiate the 
printing of page headings. 

Action taken by GEEPR: 


On Termination: Status returns are passed back to user program. 


Major Status: Command Reject (0101) Substatus: Invalid Operation Code (XXXXX1) 


Meaning of Status Return: 
Fither the operation code is unrecognizable or a parity error exists on a otherwise 
legitimate operation code. 

Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 
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PRINTER (Continued) 


Major Status: Command Reject (0101) Substatus: Slew Alert on last slew operation (X1XXXX) 


Meaning of Status Return: 
The last command resulted ‘in a termination interrupt with Data Alert status and Slew 
Alert substatus. 

Action taken by GEEPR;: 


On Termination: A message is typed informing the operator of the Alert condition, then 
status and substatus are returned to the user, 


Major Status: * Command Reject (0101) Substatus: Top-of-page Echo on last slew operation 
Se (1XXXXX) 


Meaning of Status Return: 
The last command resulted in a termination interrupt with Data Alert status and Top-of- 
Page substatus. 

Action taken by GEEPR: 
On Initiation: Status returns are passed back to user program. 
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MAGNETIC TAPE 
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(0000) Substatus: None (000000) 
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Meaning of Status Return: 


if this status is received as aii initiation interrupt in response to an REQS or RESS, the 
magnetic tape subsystem is ready to accept a new command. 


If this status is received as a termination interrupt, it indicates the command execution 
was error free and the magnetic tape subsystem is ready to accept a new command. 


Channel Ready major status may have no substatus or may have 1 or both of the following 
substatus conditions accompany it. 


Action taken by GEEPR: 


On Initiation and Termination: Status returns are passed back to user program. 
Major Status: *Channel Ready (0000) Substatus: Last tape handler Write Inhibited (0000X1) 


Meaning of Status Return: 


The tape on the last tape unit addressed has had the "write enable’' ring removed from it. 


Action taken by GEEPR: 


On Initiation and Termination: Status returns are passed back to user program. 


Major Status: *Channel Ready (0000) Substatus: Last tape handler on Load Point (00001X) 


Meaning of Status Return: 
The tape on the last tape unit addressed is currently positioned at the load point (it is 
ready to read or write the first physical record on tape). 

Action taken by GEEPR: 


On Initiation and Termination: Status returns are passed back to user program. 
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MAGNETIC TAPE (Continued) 
Major Status: Device Busy (0001) Substatus: None (000000) 


Meaning of Status Return: 
This status will never be seen by a program using GEIOS. The addressed tape unit is 
rewinding or, if this is a cross-barred tape system, the addressed tape unit is executing 
a command from the second controller. 


Action taken by GEE PR: 


On Initiation: GEEPR will reinitiate the I/O action after all other requests queued for 
that channel have been handled. 


Major Status: Attention (0010) Substatus: Tape Write Inhibited (OXXXX1) 


Meaning of Status Return: 
A write command has been addressed to a tape unit on which the tape reel does not have a 
“write enable" ring. 

Action taken by GEEPR: 


On Initiation: No manual backspacing is required. A message is typed to the operator 
giving him the following options: 


a) Take corrective action and then retry the command, or 
b) Call in a hardware test routine. or 


c) Abort the program, or initiate a rollback procedure, 
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MAGNETIC TAPE (Continued) 


Meaning of Status Return: 
A command has been addresscd to a tape unit that does not exist within the system. 
Valid logical tape unit numbers are from 0 through 15; any physical unit may be set 
to any unique logical tape unit number. 

Action taken by GEEPR: 


On Initiation: No manual backspacing is required. A message is typed to the operator 
giving him the following options: 


a) Take corrective action and then retry the command, or 
b) Call in a hardware test routine, or 


c) Abort the program, or initiate a rollback procedure. 


Major Status: Attention (0010) Substatus: MTU Standby (OXX1 XX) 


Meaning of Status Return: 


The addressed tape unit is physically present but is not in the Ready state - it is in 
Standby. This can be caused by: 


a) A rewind/standby command. 
b) The operator has manually put the unit in standby. 
c) A previous write operation resulted in the Blank tape on Write - Device Attention 
being set. 
Action taken by GEEPR: 


On Initiation: No manual backspacing is required. A message is typed to the operator 
giving him the following options: 


a) Take corrective action and then retry the command, or 

b) Call in a hardware test routine, or 

c) Abort the program, or initiate a rollback procedure. 

On Termination: This unrecoverable error is due to either operator error or hardware 


malfunction. GEEPR will give the operator the option of calling in a hardware test routine 
or aborting the program. 
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MAGNETIC TAPE (Continued) 
Major Status: Attention (0010) Substatus: MTU Check (0X1 XXX) 


Meaning of Status Return: 


Some malfunction (such as broken tape) within the addressed tape unit has resulted in an 
inoperable condition that makes further operation physically impossible. 


Action taken by GEEPR: 


On Initiation: A message is typed to the operator giving him the following 
options: 


a) Take corrective action and then retry the command, or 

b) Call in a hardware test routine, or 

c) Abort the program, or initiate a rollback procedure. 

On Termination; This inoperable condition is caused by some hardware malfunction-- 


recovery is not possible. GEEPR will give the operator the option of calling in a test 
routine or aborting the program. 


Major Status: Attention (0010) Substatus: Blank Tape on Write (01XXXX) 


Meaning of Status Return: 


A write operation had actually been started on the addressed handler but the read after 
write check was unable to detect any characters. 


Action taken by GEEPR: 
On Termination: © This inoperable condition is caused by some hardware malfunction- 
recovery is not possible. GEEPR will give the operator the option of calling in a test 


routine or aborting the program. 
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MAGNETIC TAPE (Continued) 
Maior Status:* Data Alert (001) Substatus: Transfer Timing Alert (00000X) 


Meaning of Status Return: 


The IOC did not send (write) or receive (read) data characters at a rate compatible with 
the transfer rate of the system. 


Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 


Major Status: *Data Alert (0011) Substatus: Blank Tape on Read (XXXX10) 


Meaning of Status Return: 
After the receipt of a read command, 30 inches of tape has been passed over without the 
detection of any character previously being written on the tape. 

Action taken by GEEPR: 
On Termination. Since this condition may be the result of either a hardware failure or 
of trying to read a new tape that has never been written on, this status/substatus is 
returned to the user program so that he may take whatever action is appropriate to his 


specific needs, 
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MAGNETIC TAPE (Continued) 
Major Status: Data Alert (0011) Substatus: Transmission Parity Alert (XXX1X0) 


Meaning of Status Return: 
Incorrect parity was detected on a data character received from the IOC. This can occur 
only during a "'write’' operation. 

Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 


Major Status: *Data Alert (0011) Substatus: Lateral Parity Alert (XX1XX0) 
Meaning of Status Return: 


During a write or a read operation either a missing character is detected or lateral 
(character) parity is detected. 


Action taken by GEEPR: 


See action taken for Longitudinal Parity Alert (next page). 
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MAGNETIC TAPE (Continued) 
Major Status: *Data Alert (0011) Substatus: Longitudinal Parity Alert (X1XXX0) 


Meaning of Status Return: 


During a write or a read operation, the recorded check character does not agree with the 
calculated check character. 


Action taken by GEEPR: 
On Termination: 


For Reading: When GEEPR encounters a parity error while reading, the tape is backspaced 
and the read is tried again. If after trying the read N times (N will be 10, but may be 
changed by an EQU card), a parity alert is still detected, the tape is backspaced once more 
and the record is reread with a GEEPR-created instruction having a word count of 3. If 

the DCW residue contains a number X (X#0), then the record just read was noise. 


The noise record is ignored, and with the tape now positioned beyond the noise record the 
read tape command is reissued and the following physical record is read. 


If the DCW residue contains a zero then the record just read was not noise but is a valid 
data record with parity. The tape is backspaced and the read cumumand reissued. If 
parity still exists. after repeating the cvele N times, the operator is given the option of 
reirying aiuther N times, ur of having the status,/substatus rcturned to the user program. 
The user program may now ignore the record or initiate his own recovery action. 

For Writing: When GEEPR encounters a parity error while writing, the tape is backspaced 
and the write is retried. This cycle is repeated N times (N will be 10, but may be changed 
by an EQU card), if still unsuccessful the tape is erased (about 9 inches) and the cycle 
retried N times. If still unsuccessful the erase is repeated for a total of 3 erases (or 


about 27 inches of tape) and the write is retried another N times. If parity still exists the 
operator is given the option of calling in a hardware test routine or aborting the program. 


Major Status: *Data Alert (0011) Substatus: End Tape Mark (1XXXX0) 


Meaning of Status Return: 
During a write operation, the tape handler has detected the end-of-tape reflective foil. 
This write operation will proceed to its normal termination and any subsequent write 
commands will be executed normally. The portion of tape beyond the end-of-tape foil 
should be used only for end-of-tape labels and checkpoint memory dumps. 

Action taken by GEEPR: 


On Termination: Status returns are passed back to user program. 
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MAGNETIC TAPE (Continued) 
Major Status: Data Alert (0011) Substatus: Bit detected during erase (XXXX11) 


Meaning of Status Return: 
This status is sent when a bit is detected in that portion of tape that should have been 
erased as the result of either an erase or a write-end-of-file command. 

Action taken by GEEPR: 
On Termination: The Data Alert— Bit detected during erase status/substatus is 
changed toa Channel Ready status and it is returned to the user. If there is truly a 


noise bit on the tape, this will be successfully handled when the tape is read (see action 
for Longitudinal Parity Alert). 


Major Status:* End of File (0100) Substatus: Single data character (¥ 779) (XXXXXX) 
but not (111111) 
Meaning of Status Return: 
During the execution of a read, backspace or forwardspace command, a single character 
record accompanied by its longitudinal check character was detected. If the operation was 
completed with no Data Alert condition, the substatus character wili be the bit configu- 
ration of the single character end-of-file record for a file written in the binary mode, or 


an octal 17 for a file written in the decimal mode. 


NOTE: The write single character record (WFM-write file mark) can be used with files 
written and read only in the binary mode. 


The write end-of-file (WEF) may be used with either BCD or binary files. 


Action taken by GEEPR: 
On Termination: Status returns are passed back to user program. 
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MAGNETIC TAPE (Continued) 
Major Status: *End of File (0100) Substatus: Data Alert (=779) (111111) 


Meaning of Status Return: 
A data alert condition was detected during the reading of an end-of-file record. 
NOTE: If a programmer specifies 77 as a legitimate end-of-file character, he will have 
no way of knowing whether a data alert condition exists or whether this is truly his 
special end-of-file character for files written in the binary mode. 
If a file is written in the BCD mode, and the programmer uses WFM to write a special 
single character record, when reading his file and the end-of-file is encountered, the 
End-of- File major status will always be sent with an octal 77 substatus. 


Action taken by GEEPR: 


On Termination: Status returns are passed back to user program. 


op) 


Major Status: Command Reject (0101) ubstatus: Invalid Operation Code (OXXXX1) 


Meaning of Status Return: 


The operation code, although having correct parity, is not of a recognizable configuration. 


Action taken by GEEPR;: 
On Initiation: This unrecoverable error is in the user program. There is no possible 


recovery action that GEEPR can take. The program is aborted and an error message is 
typed to inform the operator of the error condition and the action taken. 


Major Status: Command Reject (0101) Substatus: Invalid Device Code (OXXX1X) 


Meaning of Status Return: 


The device code, although having correct parity, is not of a recognizable configuration. 


Action taken by GEEPR: 


On Initiation: This error is due toahardware malfunction. There is no possible 
recovery action that GEE PR can take. The program is aborted and an error message is 
typed to inform the operator of the error condition and the action taken. 
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MAGNETIC TAPE (Continued) 


Major Status: Command Reject (0101) Substatus: Parity Alert on Operation Device Code 
———_ (0XK1 Xx) 
Meaning of Status Return: 


A parity error is detected on either the operation code, the device code, or both. 


Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 


Major Status: *Command Reject (0101) | Substatus: Magnetic Tape on Load Point (OX1 XXX) 


Meaning of Status Return: 


A backspace, write end-of-file or Erase command was issued while the tape was po- 
sitioned at the load point. 


NOTE: An end-of-file can be written while the tape is at load point by using a Write 
Single Character Record command. 


Action taken by GEE PR: 


On Initiation: Status returns are passed back to user program. 
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MAGNETIC TAPE (Continued) 
Major Status: Command Reject (0101) Substatus: Attempted Read after Write (01XXXX} 


Meaning of Status Return: 


A program issued a read or forwardspace instruction after a write instruction had just 
been issued to this tape unit with no intervening instructions 

Action taken by GEEPR: 
On Initiation: This unrecoverable error is in the user program. There is no possible 


recovery action that GEEPR can take. The program is aborted and an error message is 
typed to inform the operator of the error condition and the action taken. 
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MAGNETIC DRUM 
Major Status:* Channel Ready (0000) Substatus: Block Address (OXXXXX) 


Meaning of Status Return: 


If this status is received as an initiation interrupt in response to an REQS or RESS, the 
magnetic drum is ready to accept a new command. 


If this status is received as a termination interrupt, it indicates the command execution 
was error free and the magnetic drum is ready to accept a new command. 


The substatus will always contain the 5 low-arder bits of the block address which isa 


measure of the actual angular position of the drum at the instant the command was 
executed. 


Action taken by GEEPR: 


On Initiation and Termination; Status returns are passed back to user program. 
Major Status: Attention (0010) Substatus: None (000000) 


Meaning of Status Return: 
This status indicates the magnetic drum is unable to accept an instruction because of 
some inoperable condition. 

Action taken by GEEPR: 


On Initiation and Termination: A message is typed to the operator giving him the 
following options: 


a) Take corrective action and then retry the command, or 
b) Call in a hardware test routine, or 


c) Abort the program, or initiate a rollback procedure. 
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MAGNETIC DRUM (Continued) 


Meaning of Status Return: 


The IOC did not send (write) or receive (read) data characters at a rate compatible with 
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Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 
c) Initiate a rollback procedure, or 


d) Abort the program. 


Major Status: Data Alert (0011) Substatus: Transmission Parity Alert (OX0X10) 


Meaning of Status Return: 
Incorrect parity was detected on a data character received from the IOC. This can occur 
only during a write operation. 

Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 
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MAGNETIC DRUM (Continued) 
Major Status: Data Alert (0011) Substatus: Invalid Select Data (0X01X0) 


Meaning of Status Return: 
The start address received during the Select command operation was invalid because it 


specified a non-existent address. 


Action taken by GEEPR: 


On Initiation: The rejected command will be reissued N times by GEEPR. (N, which is 
easily changed by an EQU card, will be 3.) If recovery is not successful, the program 
will be aborted. 


Major Status:* Data Alert (0011) Substatus: Check Character Alert (010XX0) 


Meaning of Status Return: 


During the reading of a data block from drum, the calculated check character does not 
agree with the previously recorded check character. 


Action taken by GEEPR: 


The last command execution performed on the addressed drum resulted in an attempt to 
access data outside the allowable limit of the referenced file. 


Major Status:* End-of- File (0100) Substatus: None (000000) 


Meaning of Status Return: 
The last command execution performed on the addressed drum resulted in an attempt to 
access data outside the allowable limit of the referenced file. 

Action taken by GEEPR: 


On Termination: Status returns are passed back to user program. 
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MAGNETIC DRUM (Continued) 
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Meaning of Status Return: 
This status is not sent by hardwarc but is rather a GEIOS implemented return. An 


attempt was made to read pasi the written portion of a linked drum file. 


Action taken by GEEPR: 


On Termination: Status returns are passed back to user program, 


Major Status: Command Reject (0101) Substatus: Invalid Operation Code (00XXX1) 


Meaning of Status Return: 
The received command is being rejected because the operation code is of an unac- 
ceptable conficuration, 

Action taken by GEEPR: 
On Initiation: This unrecoverable error is in the user program. There is no possible 


recovery action that GEEPR can take. The program is aborted and an error message is 
typed to inform the operator of the error condition and the action taken. 


Major Status: Command Reject (0101) Substatus: Invalid Device Code (00XX1X) 


Meaning of Status Return: 
The received command is being rejected because the device code is of an unacceptable 
configuration. 

Action taken by GEEPR: 
On Initiation: This error is due to a hardware malfunction. There is no possible 


recovery action that GEEPR can take. The program is aborted and an error message is 
typed to inform the operator of the error condition and the action taken. 
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MAGNETIC DRUM (Continued) 


Major Status: Command Reject (0101) | Substatus: Parity Alert on Operation/Device Code 
(OOX1XX) 


Meaning of Status Return: 
The received command is being rejected because a parity error has been detected on 
either the operation or device code of an otherwise acceptable command. 

Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 
c) Initiate a rollback procedure, or 


d) Abort the program. 


Major Status: Command Reject (0101) | Substatus: Invalid Command Sequence (001XXX) 


Meaning of Status Return: 
The previously issued Select Drum command has not been successfully completed but a 
Read Drum, Write Drum, Write Drum and Verify, or Drum Compare and Verify command 
has been received that requires the successful completion of the Select Drum. 

Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, whichis 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 
c) Initiate a rollback procedure, or 


d) Abort the program. 
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DISC STORAGE UNIT 


tus:* Channel Ready (0000) Substatus: None (000000) 


an initiation interrupt in response to an REQS or RESS, the 
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If this status is received as a termination interrupt, it indicates that the command 
execution was error free and the Disc Storage Unit is ready to accept a new command. 


Action taken by GEEPR: 


On Initiation and Termination: Status returns are passed back to user program. 
Major Status: Device Busy (0001) Substatus: Overridable (000000) 


Meaning of Status Return: 
This status and the following overridablo ‘not overridable substatuses will never he seen 
by a program using GEJOS. However, the status does mean that tne addressed unit is in 
the process of executing an off-line operation. 
The QOverridable substatus indicates that a Seek File command is being executed and 
this command execution may be overridden by the reception of any other Seek command. 
This substatus can only be sensed in response to an REQS or RESS. 


Action taken by GEEPR: 


On Initiation: GEIOS will reinitiate the I/O action after all other requests queued for 
that channel have been handled. 


Major Status: Device Busy (0001) Substatus: Not Overridable (000001) 


Meaning of Status Return: 


The Not Overridable substatus indicates an off-line command other than a Seek is being 


aah 


executed by the addressed file unit. This command cannot be overridden by any other 
Seek command. 
Action taken by GEEPR: 


See Overridable, above. 
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DISC STORAGE UNIT (Continued) 
Major Status: Attention (0010) Substatus: None (000000) 


Meaning of Status Return: 
The Disc Storage Unit is unable to accept an instruction because of some inoperable 
condition, 

Action taken by GEEPR: 


On Initiation and Termination: A message is typed to the operator giving him the following 
options: 


a) Take corrective action and then retry the command, or 
b) Call in a hardware test routine, or 


c) Abort the program, or initiate a rollback procedure. 


Major Status: Data Alert (0011) Substatus: Transfer Timing Alert (00000X) 


Meaning of Status Return: 
The IOC did not send (write) or receive (read) data characters at a rate compatible with 
the transfer rate of the system. 

Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 
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DISC STORAGE UNIT (Continued) 


Major Status: Data Alert (0011) Substatus: Transmission Parity Alert (OXXX10) 


Meaning of Status Return: 
Incorrect parity was detected on a data character received from the Ioc. This can occur 
only during a write operation. 

Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 


Major Status: Data Alert (0011) Substatus: Invalid Control Character (OXX1X0) 


Meaning of Status Return: 
Control characters are used to transmit the physical device address of the data to be read 
or written on disc. Before all six control characters have been received, an end data 
transfer signal is sent by the IOC to the Disc Storage Unit. 

Action taken by GEEPR: 
On Termination: This unrecoverable error is in the user program. There is no 


possible recovery action that GEEPR can take. The program is aborted and an error 
message is typed to inform the operator of the error condition and the action taken. 
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DISC STORAGE UNIT (Continued) 
Major Status: Data Alert (0011) Substatus: Internal Alert (OX1XX0) 


Meaning of Status Return: 
Any one of the folowing can result in this substatus: 
a) Parity error on character read from buffer. 
b) An inconsistency in control characters. 


c) An error condition is detected within one of the file units. 


Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 
c) Initiate a rollback procedure, or 


d) Abort the program. 


Major Status: Data Alert (0011) Substatus: Check Character Alert (01XXX0) 


Meaning of Status Return: 


During the reading of a data block from disc, the calculated check character does not 
agree with the previously recorded check character. 


Action taken by GEEPR: 
On Termination: GEEPR will retry the sequence (both the seek and the following read 


or write) N times. N, easily changed by an EQU card, willbe 3. If the alert persists, 
the status/substatus will be returned to the user program. 
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DISC STORAGE UNIT (Continued) 


=eioe ont. Km. = are Ps 
Major Siatus:* End of File 


Meaning of Status Return: 
The last command execution performed by the addressed Disc Storage Unit resulted in 
the last consecutive biock being accessed. 

Action taken by GEEPR: 
On Termination: Status returns are passed back to user program, 


Major Status: *End of Logical File (1111) Substatus: None (000000) 


Meaning of Status Return: 
This status is not sent by hardware but is rather a GEIOS implemented return. An 
attempt was made to read past the written portion of a linked file unit. 

Action taken by GEEPR: 


On Termination: Status returns are passed back to user program. 


Major Status: Command Reject (0101) Substatus: Invalid Operation Code (0000X1) 


Meaning of Status Return: 
The received command is being rejected because either the operation code is of an 
unacceptable configuration or a parity error was detected on an otherwise acceptable 
operation code. 

Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 
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DISC STORAGE UNIT (Continued) 
Major Status: Command Reject (0101) Substatus: Invalid Device Code (00001X) 


Meaning of Status Return: 
The received command is being rejected because either the device code is of an 
unacceptable configuration or a parity error was detected on an otherwise acceptable 
device code. 

Action taken by GEEPR: 
On Initiation: The rejected command will be reissued N times by GEEPR. N, which is 
easily changed by an EQU card, will be 3. If recovery is not successful, the operator is 
given the following options: 
a) Reissue N more times, or 
b) Call for a hardware test routine, or 


c) Initiate a rollback procedure, or 


d) Abort the program. 
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CONSOLE TYPEWRITER 


Pann An 


Major Status:* Channel Ready (0000) Substatus: None (000000) 


Meaning of Status Return: 


If this status is received as an initiation interrupt in response to an REQS or RESS, 
the typewriter is ready to accept a new command. 


If this status is received as a termination interrupt, it indicates the command execution 
was error free and the card reader is ready to accept a new command, 


Action taken by GEEPR: 


On Initiation and Termination: Status returns are passed back to user program. 
Major Status: Attention (0010) Substatus: None (000000) 


Moaning of Status Return: 
Thic etatus indicates the tvoewriter 1S unabie to accepi an insiruciion because uf suit 
inoperable condition. 

Action taken by GEEPR: 
On Initiation and Termination: The typewriter is inoperable. GEIOS will initiate 


a "Write Alarm” to the console which will cause the sounding of an audio alarm. The 
sounding of this alarm notifies the operator of the inoperable state of the typewriter. 


Major Status: Data Alert (0011) Substatus: Transfer Timing Alert (00000X) 


Meaning of Status Return: 
The IOC did not receive (read) data characters at a rate compatible with the transfer 
rate of the system. 

Action taken by GEEPR: 


On Termination: The command is reissued by GEEPR until it is accepted. Since the 
cause of this condition is due to a timing problem, retry will eventually correct the alert. 
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CONSOLE TYPEWRITER (Continued) 
Major Status: Data Alert (0011) Substatus: Transmission Parity Alert (OXXX10) 


Meaning of Status Return: 
Incorrect parity was detected on a data characler received from the IOC, This can 
occur only during a "write" operation. 

Action taken by GEEPR: 
On Termination: The command will be reissued N times. (N, easily changed by ar 
EQU card, will be 3), Each time the command is retried an exclamation point (!) will be 
typed for that character that has a parity error and the message will be terminated, If 


the situation persists, the operator can recognize that a hardware problem exists by the 
frequency of exclamation points. 


If recovery is not successful, a write alarm (audio alarm) will be issued to inform the 
operator of a malfunction somewhere between the IOC and the console. 


Major Status: Data Alert (0011) Substatus: Operator Input Alert (OUXX1X0) 


Meaning of Status Return: 
While typing a message, the operator realizes that what he has typed isinerror. He 
wishes to have the message ignored. By depressing the OPERATOR INPUT ERROR 
button, the operator causes this status/substatus to be returned to GEEPR, 

Action taken by GEEPR: 


On Termination: GEEPR will reissue the read command. 
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CONSOLE TYPEWRITER (Continued) 


Alort (0011) Substatus: Operator Distracted (OX1XX0) 


Meaning of Status Return: 


An interval of 30 seconds has elapsed between the receipt of a Read command and the 
antan ta 
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be typed and the actuation of the END OF MESSAGE button. 


Action taken by GEEPR: 


On Termination: Status returns are passed back to user program. 
Major Status:* Data Alert (0011) Substatus: Incorrect Format (01XXX0) 


Meaning of Status Return: 


An escape character(s) is followed by a non-permissible character in a message received 
from the IOC to be typed; or a control character (17, =(?), or T7g= (!)) is not preceded by 


the plLopes uve ul tstapes oi Tg 


NOTE: In order to type a (?) or a(!) it is necessary to precede that character with two 
escapes. 


Action taken by GEEPR: 


On Termination: Status returns are passed back to user program. 
Major Status: Data Alert (0011) Substatus: Message Length Alert (100000) 


Meaning of Status Return: 


The operator has typed more than the number of characters specified by the DCW s 
referred to by the READ command. 


Action taken by GEEPR: 


On Termination; GEEPR will type a message to the operator requesting him to 
retype the message. 
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CONSOLE TYPEWRITER (Continued) 
Major Status: Command Reject (0101) Substatus: Invalid Operation/Device Code (000001) 


Meaning of Status Return: 
The received command is being rejected because either the operation code or the device 
code (or both) is of an unacceptable configuration. 

Action taken by GEEPR: 
On Initiation: This error may be in the user program. There is no recovery action that 


GEEPR can take. The program is aborted and a message so stating is typed to the 
operator. 


Major Status: Command Reject (0101) Substatus: Parity Alert on Operation Code (000011) 


Meaning of Status Return: 
The received command is being rejected because a parity error has been detected on an 
otherwise acceptable operation code. 

Action taken by GEEPR: 
On Initiation: The command is reissued N times (N, easily changed by an EQU card, 


will be 3). If recovery is not successful, a write alarm (audio alarm) will be issued 
to inform the operator of a malfunction somewhere between the IOC and the console. 
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Checkpoint Dump (GECHEK) 


INITIALLY. C(Q) required: 


L(Checkpoint File Control Block) MBZ 


CALLING SEQUENCE 


Entry L MME GECHKEK 
Lt+1 | TRA 1,QU 
Return L+2 Next Instruction 


DESCRIPTION. A checkpoint dump is written onto the file identified by the C(Q) 9. 17° This 
file must have previously been opened via GEFRC. When the peripheral type is magnetic 
tape, any number of checkpoint dumps may be written on the file along with other data. 
When the file specified 1s disc or drum, its use must be restricted to the sole purpose of 
checkpoint dumps. No other data may appear. Again, any number of checkpoints may be 
taken on a disc or drum file as each newest one will overlay any preceding dumps. Each 
checkpoint dump will contain sufficient information for restarting of the ey ata 
later time from the point at which the checkpoint occurred. 


RESERVATIONS. Both the restart procedure and the rollback procedure provide file position: 
ing capabilities only for those files which were "open" at the time of the checkpoint and 
have GEFRC file control blocks associated with them. Any file which has been closed be- 
tween the checkpoint request and the rollback request will not be repositioned. 


If a file is closed and reopened, a new checkpoint dump should be taken to maintain a 
complete rollback capability. A MME GECHEK may not be performed in a courtesy call. 


GEFRC provides an automatic checkpoint dump at the beginning of a reel after switching tape 
on a multireel file. A connection exists, in this instance, with the instruction TRA 1,QU. 
Checkpoint and rollback will provide the address +1 of the last MME GECHEK in the upper 
half of the Q-Register. Upon return to the slave after rollback, this will insure a 
correct entry point, even if an automatic checkpoint was taken by GEFRC. 


The user also has the option of providing an additional routine in the event special slave 
processing is required as a result of a rollback. This routine will automatically be 
entered if prior to the first MME GECHEK, the entry location is placed in the upper half 
of word 14 in the slave memory area. This location may be referenced thusly: 


1 8 16 
WRD14 BOOL 15 


where the tag WRD14 may be used as an operand. 
When usin; this option, the user then has the responsibility of reentering the main body 


of his program as he sees fit. The upper half of the Q-Register will still contain the 
location +1 of the last MME GECHEK taken. 


Welt 8 es, 


_ 


RETURN CODES. After entry to the checkpoint program, certain logical checks are made. 
The results of these checks are passed back to the slave program in the lower half of 


the Q-Register. 
The codes are as follows: 
Contents of lower half 


Contents of lower half 
Contents of lower half 


Contents of lower half 


All other registers will be 
with the possible exception 


of Q=0 
of Q=1 
of Q=2 
of Q=5 


Successful checkpoint taken 


Filo specified for checkpoint not open. No checkpoint 
taken. 


Checkzoint attempted on illegal peripheral type or 
on SYSOUT file. No checkpoint taken. 


Bad status return on attempted write. An incomplete 
checkpoint dump may exist and a new checkpoint should 
be taken. 


set to the state they had immediately prior to the MME GECHEK, 
of AR, Index O and 1, and QR. 
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in 
LOB i alk 
CALLING SEQUENCE uu 


Entry L MME GEROLL | ( 0 9 \/ 


DESCRIPTION. Entry to GEROLL results in an output RAs OG RE MOM Ar, requesting 

the operator to initiate a restart of the program. If che operator's response is restart, 
the program is restarted at the last checkpoint within the current activity if such a 
checkpoint exists. 


The user is advised to place a checkpoint (MME GECHEK) at the start of his program; 
otherwise, if no checkpoint exists, the program is aborted (since GELOAD releases any 
library files as well as memory itself prior to any possible reinitiation of an activity). 


If the operator's response is no restart, the program is also aborted. 


When restart is attempted, positioning of magnetic tape files is accomplished using in- 
formation available within the user's file control biocks at the time of the checkpoint. 
The positioning of linked drum and disc files is accomplished using information contained 
in the user's peripheral assignment table at the time of the checkpoint. 


After the checkpoint recovery has taken place, control is returned to the address specifiec 
by the contents of the address field of location 14 within the user's assigned memory. 

If at the time a checkpoint is taken (via GECHEK) the address field of this location is 
zero, the checkpoint routine will place the address of the MME GECHECK plus one into this 
location. 


Note: Following any file switch, file release, or memory release procedures, the user 
should issue a MME GECHEK. This will ensure that peripheral unit assignments have not beer 
disturbed between current instruction and last checkpoint. 


Any tapes or files assigned to SYSOUT (file code of P*) will not be repositioned. All 
other files on tape should have a standard system label. Any non-standard labeled tape 
files will not be repositioned and a 4 will appear in the QR after the GEROLL return to 
the slave program. All other rollback functions will have taken place at this point. 


The rollback capability does not extend to any file not under control of GEFRC or to | 
any unopened file. 


The contents of the machine registers will be restored to the point immediately prior to 
the last checkpoint dump. Rollback will always take the positioning information given in 
the last checkpoint dump and passover to selected dumps is not possible. 


If a rollback abort and slave dump occurs with the value 3 in the QR, the indication is 
‘that no checkpoint dump was taken because of an invalid File Control Block Address as 
input to the checkpoint program. 
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DATA CONTROL WORD ; CPBw1002A 


The attached chart refers to the Data Control Word (DCW) residue as it is 


returned by the I0C at the conclusion of an I/0 operation, 


This chart supplements the discussion of the Status Return Word found on Pages 38-39 


of GE-625/635 Comprehensive Operating Supervisor (GECOS) Reference Manual ,CPB-1002A. 
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NEN ta 
Ji 


DO NOT eee 


CONDITIONS 
1/0 TERMINATION 


Command not 
accepted by 
peripheral 

DCW word count 
exhausted 


Peripheral 
recognizes 
physical 

end of record 

or e2rroc 


DCW limit 
check (high or 

low speed write, 
or low speed 


check (high 
speed read) 


WAS LAST CHARACTER 
TRANSMITTED PART 
OF LAST WORD SPEC- 
IFIED BY DCW? 


NA 


YES 


YES 


YES 


WAS LAS _ CHARACTER DGW RESIDUE 
ADDRESS FIELD 


TRANSMITTED THE 
SIXTH CHARACTER OF 
WORD? 


Specified 
address 


Last full 
word trans- 
ferred + 1] 


Last full 
word trans- 
ferred + 1] 

Specified 
address in 
next DCW 
(other than 

TDCW) 

Last partial 
word trans-~ 
ferred + ] 

Last full 
word trans- 
ferred + 1] 

Last partial 
word trans- 

ferred + 1 


NO 
YES 


NO 


Specified 
address 


Specified 
address 


Specified Word 


romana sum Be 


woman =o 


NRO ILL RRL. NE 


WORD CCUNT FIELD 


Count - 1] 


Specified word 
count in next 
DCW (other than 
TDCW) 


Zero 


Residual word 
count 


Residual word 
count (partial 
word counted as 
full word) 


Specified word 
word count 


Specified word 
word count - 1 
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